经过了连续两天的跟踪,django终于在俺的机器上跑起来了。 走了不少弯路,想想还是把遇到的问题写下来吧,让大家能够节省点时间。
- 下载
apache 2.0.54: 点击下载
mod_python 3.1.4: 源码下载 没找到win32版本的,自己编译, 配置两个环境变量PYTHONSRC和APACHESRC, 用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>