使用Apache& amp; django时出错mod_wsgi的

时间:2010-03-14 20:53:03

标签: django apache mod-wsgi

嘿,我正在对你的django发展环境进行一些改动,正如你们有些人所说的那样。 到目前为止,我已经设法使用postgres成功配置并运行它。

现在我正在尝试使用apache2和mod_wsgi来运行应用程序,但是在我遵循django文档中的指南后,我遇到了这个小问题。

当我访问localhost / myapp / tasks时,此错误会引发:

    Request Method:   GET
Request URL:  http://localhost/myapp/tasks/
Exception Type:  TemplateSyntaxError
Exception Value:  

Caught an exception while rendering: argument 1 must be a string or unicode object

Original Traceback (most recent call last):
  File "/usr/local/lib/python2.6/dist-packages/django/template/debug.py", line 71, in render_node
    result = node.render(context)
  File "/usr/local/lib/python2.6/dist-packages/django/template/defaulttags.py", line 126, in render
    len_values = len(values)
  File "/usr/local/lib/python2.6/dist-packages/django/db/models/query.py", line 81, in __len__
    self._result_cache = list(self.iterator())
  File "/usr/local/lib/python2.6/dist-packages/django/db/models/query.py", line 238, in iterator
    for row in self.query.results_iter():
  File "/usr/local/lib/python2.6/dist-packages/django/db/models/sql/query.py", line 287, in results_iter
    for rows in self.execute_sql(MULTI):
  File "/usr/local/lib/python2.6/dist-packages/django/db/models/sql/query.py", line 2369, in execute_sql
    cursor.execute(sql, params)
  File "/usr/local/lib/python2.6/dist-packages/django/db/backends/util.py", line 19, in execute
    return self.cursor.execute(sql, params)
TypeError: argument 1 must be a string or unicode object
... ... ...

然后它突出显示{%for t in tasks%}模板标记,就像问题的来源一样,但它在内置服务器上运行良好。

与该页面关联的视图真的简单,只需获取所有Task对象。模板只是将它们显示在桌面上。

此外,部分页面也可以呈现。 不想用代码填写这个问题,所以如果你需要更多的信息,我很乐意提供它。感谢

修改

所以,这是我的观点:

@login_required
def tasks(request, msg=''):
    tasks = Task.objects.all()
    message = msg
    return custom_render('user/tasks.html',
                         {'tasks': tasks, 'message':message},
                         request)

这是我的模板:

{% block main_content %}

{% if message %}
    <p id="message" class="info">
        {{message}}
    </p>
{% endif %}

<a href="{% url GProject.myapp.views.new_task %}">Nueva Tarea</a>

    <table  id="tasks-table" >
        <thead>
            <tr>
                <th colspan="4" >{{tasks|length}} tareas pendientes</th>
            </tr>
            <tr>
                <th>#</th>
                <th>Proyecto</th>
                <th>Título</th>
                <th>Estado</th>
            </tr>
        </thead>
        <tbody>
            {% for t in tasks %}
                <tr id="row-{{t.id}}" class="{% cycle 'row-0' 'row-1' %} priority-{{ t.priority }}">
                    <td width="25">
                       <a href="{% url GProject.myapp.views.view_task t.id %}">{{t.id}}</a>
                   </td>
                   <td>
                       <a href="{% url GProject.myapp.views.view_task t.id %}">{{t.project}}</a>
                   </td>
                   <td width="400">
                       <a href="{% url GProject.myapp.views.view_task t.id %}">
                           {{t.title}}
                       </a>
                   </td>
                   <td>{{t.get_status_display}}</td>
                </tr>
            {% empty %}
                <tr><td>No tasks</td></tr>
            {% endfor %}

        </tbody>
    </table>
{% endblock main_content %}

此外,现在我收到错误:

TypeError at /admin/tareas/

argument 1 must be a string or unicode object

Request Method:  GET
Request URL:  http://localhost/gpro/admin/tareas/
Exception Type:  TypeError
Exception Value:  

argument 1 must be a string or unicode object

Exception Location:  /usr/local/lib/python2.6/dist-packages/django/db/backends/postgresql_psycopg2/base.py in _cursor, line 105
Python Executable:  /usr/bin/python
Python Version:  2.5.4

修改

任务模型如下所示:

class Task(models.Model):

    project = models.ForeignKey(Project)
    title = models.CharField(max_length=128)
    description = models.TextField(max_length=1500)
    effort = models.IntegerField(null=True, blank=True)
    priority = models.IntegerField(max_length=1, null=True, blank=True, choices=PRIORITY_VALUES)
    severity = models.IntegerField(max_length=1, null=True, blank=True, choices=SEVERITY_VALUES)
    asignee = models.ForeignKey(User, blank=True, null=True, related_name='asignee')
    milestone = models.ForeignKey(Milestone, blank=True, null=True)
    created_by = models.ForeignKey(User, blank=True, null=True, related_name='created_by')
    status = models.IntegerField(max_length=1, choices=STATUS_VALUES, default=1)
    resolution_comment = models.CharField(max_length=1500, null=True, blank=True) #comentario al resolver la task
    due_date = models.DateField(blank=True, null=True)
    created_on = models.DateTimeField(auto_now_add = True)

    #print    
    def __unicode__(self):
        return self.title

custom_render:

def custom_render(template_name, data_dict, request):
    return render_to_response(template_name,
                              data_dict,
                              context_instance=RequestContext(request))

1 个答案:

答案 0 :(得分:0)

假设您没有遇到运行manage.py runserver的问题,并且使用mod_wsgi遇到问题,我会查看数据库权限。

首先,您是否正在运行mod_wsgi作为运行python manage.py runserver的用户?如果不是,则需要授予mod_wsgi用户权限。例如,尝试这样的事情,其中​​apache是​​运行mod_wsgi的用户的名字:

sudo su - postgres
createuser -S -D -R apache
psql
< should now be in the psql shell >
grant all on database < your database name > to apache;