python Web开发框架-Django (2)
接上篇文章,介绍一些实用的技巧和注意点。首次用MarkDown编辑,感觉行空隙太大,不是那么好看。
GET/POST
前后端会有数据交互,使用JQuery来实现get/post请求
GET
方法1:通过正则表达式匹配url传递参数
$.ajax({
type:"GET",
url:"/search/serviceInfo/" + $('#servicename').val() + "/",
dataType: 'json',//预期服务器返回的数据类型,我喜欢用json,当然你可以用xml/text/responseXML等
success: function(msg) {
//获取服务端返回的数据
var logNames = msg['logName'];//读取json中的字段
document.getElementById('logs').innerHTML = logNames;
},
});
通过url路径传递参数,需要urls.py配置
//urls.py
urlpatterns = patterns('',
(r'^search/serviceInfo/(.+)/$', 'searchText.getServiceInfo'),
)
//searchText.py
def getServiceInfo(request, servicename):
result = {}
//something about servicename
return HttpResponse(json.dumps(result))
方法2:request parameter
//.ajax同上
url:"/search/searchLog/?offset=" + tmpOffset + "&count=" + pageCount
//后台获取参数,视图函数
def searchLog(request):
offset = request.GET.get('offset');
count = request.GET.get('count');
//something
POST
提交表单或者上传数据往往用post
//前端js
logConf = {};
//something
$.ajax({
type:"POST",
url:"/setting/updschema/",
data:JSON.stringify(logConf),
dataType:'json',
success: function(msg) {
//something
}
});
//后台py接收
def addSchema(request):
conf = json.loads(request.body)
#中文转换,前端过来的数据是unicode格式,需要一次转码
logSchema.servicename = conf["servicename"].encode('utf8')
logSchema.fields = json.dumps(conf['fields'])
logSchema.monitorLines = json.dumps(conf['lines'])
//something...
json对象和字符串的转换:在js和python中,json对象对应的是字典、序列,各脚本语言都提供的有字符串转为字典/序列对象、对象转为json串的方法。
//js
JSON.stringify(obj)将JSON转为字符串
JSON.parse(string)将字符串转为JSON对象
//python
json.dumps(obj)JSON转为字符串
json.loads(str)字符串转为JSON
CSRF: Cross Site Request Forgery跨站请求伪造,为了确保请求的真实性django提供了防止csrf攻击的方法,在post时需要请求带上csrf token。所以使用post时会遇到csrf相关的错误,请求被拒绝。正规解决办法见django csrf protection。
后台程序员做的web服务多是内部使用,提供一个绕开csrf的方法。修改settings.py关掉csrf验证,如下
MIDDLEWARE_CLASSES = (
//....注释掉下面这行
#'django.middleware.csrf.CsrfViewMiddleware',
//....
)
数据返回
//后端返回页面或json数据
#返回新页面
return render_to_response('current_datetime.html')
#返回json数据,result是一个字典
return HttpResponse(json.dumps(result))
log使用
在settings.py中设置log
import logging
from logging.handlers import *
from logging import Formatter
root = logging.getLogger()
if len(root.handlers) == 0:
#日志路径
filename = os.path.join(BASE_DIR,'log/tulip.log').replace('\\','/')
#日志格式
format = '%(asctime)s %(levelname)s %(module)s.%(funcName)s Line:%(lineno)d %(message)s'
#归档切换
rotate = TimedRotatingFileHandler(filename,"midnight",1,5)
fmt = Formatter(format)
rotate.setFormatter(fmt)
root.addHandler(rotate)
#log level,如下debug及其以上都会显示
root.setLevel(logging.DEBUG)
在后台python中就可以直接使用log了:
import logging
logging.info(str)
logging.debug(str)
logging.warn(str)
#....
前端
模板:搜bootstrap模板,可以看到很多漂亮简洁的前端模板
jquery:
//样式管理
$('#servicenameErr').addClass('has-error');
$('#servicenameErr').removeClass('has-error');
//取值
servicename = $('#servicename').val();
//ajax
$.ajax({});
HTML DOM:
//清除selector的option,很简单哟
document.getElementById("logName").length = 0;
//表格行删除
document.getElementById('fieldTable').deleteRow(index);
//表格行增加
row =document.getElementById('fieldTable').insertRow(index);
row.innerHTML = "xxx";
//遍历表格
var fieldRows = document.getElementById('fieldTable').rows;
for (var i = 1; i < fieldRows.length; ++i) {
var cells = fieldRows[i].cells;
name = cells[0].childNodes[0].value;//单元格中有个input控件
}
//设置控件内容
document.getElementById('xxx').innerHTML="";//可以带html标签
document.getElementById('xxx').innerText ="";//纯文字
一款漂亮的alert-toastr:
toastr.options['positionClass'] = 'toast-top-center';
toastr.options['timeOut'] = "1000";
toastr.success('配置成功');
一款好用的日历控件-My97DatePicker
//注意到在onclick指出了日历的调用、日期格式、以及取值限制
<script language="javascript" type="text/javascript" src="/static/My97DatePicker/WdatePicker.js"></script>
<input id="startTime" type="text" placeholder="起始时间" onClick="WdatePicker({dateFmt:'yyyy-MM-dd HH:mm:ss',maxDate:'#F{$dp.$D(\'endTime\')}'})"/>
<input id="endTime" type="text" placeholder="终止时间"
onClick="WdatePicker({dateFmt:'yyyy-MM-dd HH:mm:ss',minDate:'#F{$dp.$D(\'startTime\')}'})"/>
参考资料
Django book: http://djangobook.py3k.cn/2.0/
Django下载:https://www.djangoproject.com/download/
bootstrap前端框架:http://www.bootcss.com/
JQuery:http://www.w3school.com.cn/jquery/
HTML DOM:http://www.w3school.com.cn/htmldom/
toastr:https://github.com/CodeSeven/toastr
My97DatePicker:http://www.my97.net/
django csrf:https://docs.djangoproject.com/en/dev/ref/csrf
python Web开发框架-Django (2)的更多相关文章
- 全面解读Python Web开发框架Django
全面解读Python Web开发框架Django Django是一个开源的Web应用框架,由Python写成.采用MVC的软件设计模式,主要目标是使得开发复杂的.数据库驱动的网站变得简单.Django ...
- 全面解读Python Web开发框架Django,利用Django构建web应用及其部署
全面解读Python Web开发框架Django Django是一个开源的Web应用框架,由Python写成.采用MVC的软件设计模式,主要目标是使得开发复杂的.数据库驱动的网站变得简单.Django ...
- Python Web开发框架Django
花了两周时间,利用工作间隙时间,开发了一个基于Django的项目任务管理Web应用.项目计划的实时动态,可以方便地被项目成员查看(^_^又重复发明轮子了).从前台到后台,好好折腾了一把,用到:HTML ...
- 分分钟教你Python Web开发框架Django
Python除了爬虫.深度学习(人工智能).数据分析等外,还可以用来开发网站系统,如我们常见的知乎,豆瓣等都是用Python开发的网站系统. 今天辰哥就来教大家如何新建属于自己的Django项目,让D ...
- python Web开发框架-Django (1)
以前用web.py(另外一款轻量级web开发框架)做一个监控管理平台,没有做特别的记录就不好拾起来.最近做一个日志聚合系统,使用的是django,这次就记下来,方便查询. Django是一个高效的we ...
- 5个最好的Python Web开发框架
Python是最受欢迎的和最有效率的开发语言之一.Python能让你更快完成工作,并且更有效地集成系统.Python是动态的面向对象的语言.即便你刚刚开始学习Python,也立即就能获得生产力上的提升 ...
- 我的第一个python web开发框架(14)——后台管理系统登录功能
接下来正式进入网站的功能开发.要完成后台管理系统登录功能,通过查看登录页面,我们可以了解到,我们需要编写验证码图片获取接口和登录处理接口,然后在登录页面的HTML上编写AJAX. 在进行接口开发之前, ...
- Python web(Django)连接Sql server
(开开心心每一天~ ---虫瘾师) Python Web(Django) 与SQL SERVRE的连接----Come QQ群:607021567(里面有很多开源代码和资料,并且python的游戏也有 ...
- Python Web(Django)与SQL SERVER的连接处理
(开开心心每一天~ ---虫瘾师) Python Web(Django) 与SQL SERVRE的连接----Come QQ群:607021567(里面有很多开源代码和资料,并且python的游戏也有 ...
随机推荐
- Hadoop2.6.0的FileInputFormat的任务切分原理分析(即如何控制FileInputFormat的map任务数量)
前言 首先确保已经搭建好Hadoop集群环境,可以参考<Linux下Hadoop集群环境的搭建>一文的内容.我在测试mapreduce任务时,发现相比于使用Job.setNumReduce ...
- 不同包中继承关系访问protected内部类问题
有两个包pack1和pack2,pack1中是父类,pack2中子类继承自pack1中的父类.这里主要探索一下子类访问父类中protected内部类的问题: 第一个类: package pack1; ...
- 一个书店管理系统java
自己的第一个小程序 ps:书是在集合里面后面文件处理的有一点小问题,希望有人会给点意见 //客户类 import java.io.Serializable; public class Customer ...
- ORACLE 查询一个数据表后通过遍历再插入另一个表中的两种写法
ORACLE 查询一个数据表后通过遍历再插入另一个表中的两种写法 语法 第一种: 通过使用Oracle语句块 --指定文档所有部门都能查看 declare cursor TABLE_DEPT and ...
- tomcat详情
[转载]http://grass51.blog.51cto.com/4356355/1123400
- redis连接超时报错
应用程序连接redis超时,报错如下: ERROR DubboServerHandler-xxx.xx.xx.52:20880-thread-172 2016-12-21 15:25:20,429 c ...
- 【线段树】bzoj1756 Vijos1083 小白逛公园
我们知道,求一段序列的最大子段和是O(n)的,但是这样是显然会超时的. 我们需要一个数据结构来支持修改和计算的操作,对于这种修改一个而查询区间的问题,考虑使用线段树. 在线段树中,除了左端点,右端点, ...
- Centos 6.X基本维护操作
设置163源,全新最小化安装时,更改源需先yum install wget mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-B ...
- About MTU,TCP-MSS (转)
MSS是Maxitum Segment Size 最大分段大小的缩写,意为TCP数据包每次能够传输的最大数据分段,是TCP协议里面的一个概念.MSS值所表示的是TCP报文的净载荷数据大小.通过设置其大 ...
- Swift语法简介(一)
或许网络上有很多成型的介绍,我只想写下来留给自己.欢迎批评.开撸! 1.第一个程序,Hello,world!古人云,学会了Hello,world!这门语言你就掌握了一半了. print("H ...