经过了连续两天的跟踪,django终于在俺的机器上跑起来了。 走了不少弯路,想想还是把遇到的问题写下来吧,让大家能够节省点时间。

  • 下载

apache 2.0.54: 点击下载

mod_python 3.1.4: 源码下载 没找到win32版本的,自己编译, 配置两个环境变量PYTHONSRCAPACHESRC, 用python对应的编译器(python2.4=vc71)编译即可,win32版本的mod_python 3.1.4可以到http://www.lehuen.com/nicolas/download/mod_python/下载

pyscopg1 1.1.18: 点击下载

posggresql 8.0: 点击选择合适的下载

  • Apache配置

httpd.conf:

# 修改DocumentRoot
DocumentRoot "d:/myproject/django/wwwpub" # 此处是你的web发布目录, 用于存放静态文件
# 修改下面对应DocumentRoot项的<Directory>标记
<Directory "d:/myproject/django/wwwpub">
   .... # 省略
</Directory>

# 增加下面的标记,用于映射url http://localhost:8080/admin/下的访问
<Location /admin/>
    SetHandler mod_python
    PythonHandler django.core.handler
    SetEnv DJANGO_SETTINGS_MODULE testproj.settings.admin
</Location>

细心的朋友会发现上面没有映射根(/), 因为俺也没有研究出来, 当按/admin/的方式映射根时, 根下所有的静态文件都不能访问了(必然的结果:(), 等adrian的教程3吧

  • Python配置

保证django在sys.path中能够找到

( 以下部分抄自原版教程, 只说关键部分吧 )

  • 初始化项目

在wwwpub之外随便找一个目录,但要求能在sys.path中找到, 执行:

python xxxx\django\bin\django-admin.py startproject testproj

该命令会在当前执行目录下建立一个testproj目录,用于存放该项目的model,url映射,视图和模版.

执行后,进入testproj\apps, 执行:

python xxxx\django\bin\django-amdin.py startapp polls

该命令就建立了一个polls目录, 里面就可以放置testproj项目的polls应用的具体内容了.

编辑testproj\settings\main.py, 配置数据库参数

执行set DJANGO_SETTINGS_MODULE=testproj.settings.main, 注意不要加引号, 教程里加引号win下不正确

执行

python xxxx\django\bin\django-amdin.py init 

来初始化数据库.

按教程说明编写polls.py文件. 并配置testproj.settings.main中的INSTALLED_APPS

执行

python xxxx\django\bin\django-amdin.py install polls

django会自动根据polls.py文件中的模型建表.

按照教程01中Playing with the API的内容操作. 此处体现了python的强大. 你只需要定义一个模型对象, 所有的操作自动给你构造好了. OK, 完成这一小节的操作后,数据库中就增加了几条记录了.

  • 使用管理界面

拷贝 trunk下的media目录到wwwpub下, 启动apache server看看能不能访问/media/img/下的图片

按照教程02中Create a user account的内容创建一个用户.

使用 http://127.0.0.1:8080/admin/ 登录管理界面. 如果登录不报错, 但总是在登录界面循环, 需要在testproj.settings.admin中增加

REGISTRATION_COOKIE_DOMAIN = '127.0.0.1'
  • 管理polls项目的对象

很简单,按照教程一步一步来就行了.

( 继续教程,我们来实现我们自己的应用 )

  • 配置URL映射

在testproj.settings.urls.main 中的urlpatterns中加入一行:

#python 
    (r'^polls/', include('testproj.apps.polls.urls.polls')),

然后后在 testproj.apps.polls.urls.polls中加入一行:

#python 
    (r'^(?P<pid>\d+)$, 'polls.view_poll')),

注意此处只是指定的polls.view_poll,因为在这行只上有一个限定前缀

#python 
urlpatterns = patterns('testproj.apps.polls.views',
  • 配置template目录

在testproj.settings.main中增加:

#python 
TEMPLATE_DIRS = (
    r'D:\myproject\django\trunk\testproj\apps\polls\templates' ,
)

确定该目录的存在,尽量不要把模版文件放到wwwpub目录下

  • 实现Views

来个最简单的吧

testproj.apps.polls.views.polls:

# coding: gb2312
from django.models.polls import polls
from django.core import template_loader
from django.core.extensions import DjangoContext as Context
from django.utils.httpwrappers import HttpResponse, HttpResponseRedirect

def view_poll( request , id ):
        p = polls.get_object( id__exact = '1' )
        t = template_loader.get_template('viewpoll')
        c = Context(request, {'pollobj': p })
        return HttpResponse(t.render(c))
  • 实现模版viewpoll

在templates目录下建立文件viewpoll.html

<html>
<body>
<title>test</title>
{{ pollobj.question }}
</body>
</html>
  • 最后一步,配置mod_python

# 增加下面的标记,用于映射url http://localhost:8080/polls/下的访问
<Location /polls/>
    SetHandler mod_python
    PythonHandler django.core.handler
    SetEnv DJANGO_SETTINGS_MODULE testproj.settings.main
</Location>

启动apache,然后访问http://localhost:8080/polls/1看看有没有效果 :)

OK,大功告成。现在你可以随意发挥了。美中不足的就是还不能把根映射为应用,当然在/index.htm里面直接重定向也可以。 另外使用polls/aaa.htm这种静态页面也没有办法,只能增加一个url映射然后用file读出来。

django还需要进化。

  • 体会 URL mapping很有效。 model 的实现相当精美。特别是数据库直接建表。但是再使用一段时间后改表只能用 djangoamdin sql 命令将sql导出再人工处理了。不过作者已经做了足够多了。 另外middleware仅仅是功能的扩充。也算是server段的hack代码吧 其他,还没体会出来。。。

--

  • fluke 的 Apache配置(补充上面没有能解决的根的问题)

# setting up a normal virtual host
# 这个虚拟主机不用经过mod_python
<VirtualHost *>
    ServerName sgu.ospattern.net
    DocumentRoot "/var/www/sgu.ospattern.net/html"
    SetHandler NONE
</VirtualHost>

# optional a django_ojs path
# 这个和上面的那个配置一样
<Location "/ojs">
    SetHandler python-program
    PythonHandler django.core.handlers.modpython
    PythonPath "['/home/fluke/Projects'] + sys.path"
    SetEnv DJANGO_SETTINGS_MODULE django_ojs.settings
    PythonDebug On
</Location>

# setting up a vertual host
# 这里就不一样了,设置了基于域名的虚拟主机,根目录也是django的 :)
<VirtualHost *>
    ServerName ojs.ospattern.net
    SetHandler python-program
    PythonHandler django.core.handlers.modpython
    # 下面设置路径
    PythonPath "['/home/fluke/Projects'] + sys.path"
    SetEnv DJANGO_SETTINGS_MODULE django_ojs.settings
    #SetEnv ROOT_URLCONF django_ojs.urls
    PythonDebug On
</VirtualHost>

# leave the /media/ dir for serving css & img files
<Location "/media/">
    SetHandler None
</Location>

# leave the /phpMyAdmin/ dir for manage the database
<Location "/phpMyAdmin/">
    SetHandler None
</Location>

# leave img files not be interpreted by python
<LocationMatch "\.(jpg|gif|png|mp3|wma)$">
    SetHandler None
</LocationMatch>


希望这个配置对某些人有用:)

--

--
张骏 <zhangj at foreseen-info dot com>