django restul webservice返回json数据
做这个demo的前提是你已经配好了python ,django ,djangorestframwork(在我的上一篇博客中有介绍,大家也可以google),mysql-python等。
djangorestframwork的官网点击打开链接http://django-rest-framework.org/
工程目录:
下面开始:
models.py 主要负责数据库对象的映射
- '''
- Created on 2013-9-19
- @author: lele
- '''
- from django.db import models
- # Create your models here.
- class Student(models.Model):
- id=models.IntegerField(primary_key=True)
- Pname= models.CharField(max_length=500)
- age=models.IntegerField()
- class Meta:
- ordering = ('id',)
序列化:
serializers.py
- # -*- coding: UTF-8 -*-
- '''
- Created on 2013-9-19
- @author: lele
- '''
- from django.forms import widgets
- from rest_framework import serializers
- from models import Student,Content
- class StudentSerializer(serializers.ModelSerializer):
- mystudentsdetail = serializers.HyperlinkedRelatedField(many=True, view_name='student-detail')
- class Meta:
- model = Student
- fields = ('id', 'Pname','age')
- id = serializers.IntegerField() # Note: `Field` is an untyped read-only field.
- Pname= serializers.CharField(max_length=100)
- age=serializers.IntegerField()
- def restore_object(self, attrs, instance=None):
- """
- Create or update a new snippet instance.
- """
- if instance:
- # Update existing instance
- instance.Panme = attrs['Pname']
- instance.id = attrs['id']
- instance.age = attrs['age']
- return instance
- # Create new instance
- return Student(**attrs)
views.py:
- '''
- Created on 2013-9-19
- @author: lele
- '''
- from django.http import HttpResponse
- from models import Student,Content
- from serializers import StudentSerializer
- from rest_framework import viewsets
- class StudentViewSet(viewsets.ModelViewSet):
- """
- This viewset automatically provides `list`, `create`, `retrieve`,
- `update` and `destroy` actions.
- Additionally we also provide an extra `highlight` action.
- """
- queryset = Student.objects.all()
- serializer_class = StudentSerializer
修改配置文件:
在settings.py中修改databases
- DATABASES = {
- 'default': {
- 'ENGINE': 'django.db.backends.mysql', # Add 'postgresql_psycopg2', 'mysql', 'sqlite3' or 'oracle'.
- 'NAME': 'test', # Or path to database file if using sqlite3.
- # The following settings are not used with sqlite3:
- 'USER': 'root',
- 'PASSWORD': '123456',
- 'HOST': '127.0.0.1', # Empty for localhost through domain sockets or '127.0.0.1' for localhost through TCP.
- 'PORT': '3306', # Set to empty string for default.
- }
- }
还是在settings.py中添加:
- REST_FRAMEWORK = {
- # Use hyperlinked styles by default.
- # Only used if the `serializer_class` attribute is not set on a view.
- 'DEFAULT_MODEL_SERIALIZER_CLASS':
- 'rest_framework.serializers.HyperlinkedModelSerializer',
- 'DEFAULT_PERMISSION_CLASSES': (
- 'rest_framework.permissions.AllowAny',
- ),
- 'PAGINATE_BY': 3, #every number in page
- 'PAGINATE_BY_PARAM': 'page_size',
- 'MAX_PAGINATE_BY': 100
- }
设置访问连接:
在urls.py设置
- from django.conf.urls import patterns, include, url
- from rest_framework import viewsets, routers
- from views import StudentViewSet
- router = routers.DefaultRouter()
- router.register(r'mystudents',StudentViewSet)
- urlpatterns = patterns('',
- url(r'^', include(router.urls)),
- url(r'^api-auth/', include('rest_framework.urls', namespace='rest_framework')),
- )
就剩最后一步了在mysql数据库中添加 数据
注意:数据库的名字与setting.py中的一致,table的名字格式是:项目名_对象名
例如我的项目名为:djangodemo2 models.py中的model对象名为student ,所以我的表名为:djangodemo2_student
有三个字段 id,Pname ,age 要与serializers.py中的fields字段相同
本例中的字段如下:
运行测试:
在浏览器中输入:http://localhost:8000 即可看到如下页面:
点击链接进入具体信息页面:
转载请注明:
新浪微博:http://weibo.com/u/3202802157
django restul webservice返回json数据的更多相关文章
- django restful webservice返回json数据
做这个demo的前提是你已经配好了python ,django ,djangorestframwork(在我的上一篇博客中有介绍,大家也可以google),mysql-python等. djangor ...
- ASP.net jQuery调用webservice返回json数据的一些问题
之前寒假时,试着使用jQuery写了几个异步请求demo, 但是那样是使用的webform普通页面,一般应该是用 webservice 居多. 最近写后台管理时,想用异步来实现一些信息的展示和修改, ...
- jQuery调用WebService返回JSON数据
相信大家都比较了解JSON格式的数据对于ajax的方便,不了解的可以从网上找一下这方面的资料来看一下,这里就不多说了,不清楚的可以在网上查一下,这里只说一下因为参数设置不当引起的取不到返回值的问题. ...
- django 使用HttpResponse返回json数据为中文
之前我用django一般用JsonResponse来返回json数据格式 但是发现返回中文的时候会乱码 from django.http import JsonResponse def test(re ...
- asp.net webservice 返回json数据乱码解决方法
[WebMethod] public void QueryRiskNotice(string phone) { try { var data = _riskNoticeDal.QueryRiskNot ...
- 【C#】WebService接受跨域请求及返回json数据
问题概述 通过Web Service发布服务供客户端调用是一种非常简单.方便.快速的手段,并且服务发布后会有一个服务说明页面,直观明了,如图: 一般情况下,在web页面中的JavaScript中调用W ...
- WebService返回json格式数据供苹果或者安卓程序调用
1.新建一个WebService. 2. /// <summary> /// DemoToJson 的摘要说明 /// </summary> [WebService(Names ...
- MOOC(2)-Django开发get、post请求,返回json数据
1.对get请求直接返回参数 如果请求多个参数,也只能返回一个参数,这里只返回了username参数 如果想要返回多个参数值,可以返回json格式数据 2.对get请求返回json数据 # views ...
- asp.net项目下的web service返回json数据问题
App_Code目录下放置WebService.cs文件,文件内容如: using System; using System.Collections.Generic; using System.Dat ...
随机推荐
- MVC推荐教程和文章列表
着手Getting Started Getting Started with ASP.NET MVC 5 (共11部分) Pluralsight ASP.NET MVC 5 Fundamentals( ...
- 【转】Uiautomator Api浅析
原文地址:http://blog.sina.com.cn/s/blog_ae2575ff01018b2o.html uiautomator api: http://android.toolib.net ...
- 怎么会Sql serverW数据库模型图转化成ord于--您还可以查看属性信息字段
1. 于Sql server数据库,创建数据库模型图 -- Database Diagrams watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvamN4NTA ...
- 蜗牛—Hibernate之初识配置
下载Hibernate的jar包 把下面jar文件考到项目lib下 然后在myeclipse中打开database的view视图创建一个新的数据库连接 接下来,配置连接,须要导入ORACLE的jar包 ...
- applet授权数字签名
一.压缩你的class类文件为jar包 1.如果你的须要压缩的类文件存在的包为:cn.mbq.test1和cn.mbq.test2 2.进入你的classes文件夹,在DOS窗体中运行命令:jar c ...
- JavaScript Date对象介绍
原文:JavaScript Date对象介绍 Date 日期和时间对象 1. 介绍 Date对象,是操作日期和时间的对象.Date对象对日期和时间的操作只能通过方法. 2. 构造函数 2.1 new ...
- C#抓取AJAX页面的内容
原文 C#抓取AJAX页面的内容 现在的网页有相当一部分是采用了AJAX技术,所谓的AJAX技术简单一点讲就是事件驱动吧(当然这种说法可能很不全面),在你提交了URL后,服务器发给你的并不是所有是页面 ...
- TRS_WCM(拓尔思信息技术有限公司)内容协作平台平台置标经验攻略
TRS_WCM置标过程中经验积累 版本V4.0-2014.6.24-穿越者7号 目录 1.嵌套模板置标 1 2.栏目名称超链接置标 1 3.列表循环输出文档标题包含超链接 1 4.取既定栏目下第一篇文 ...
- 基于protobuf的RPC实现
可以比较使用google protobuf RPC实现echo service可见.述. google protobuf仅仅负责消息的打包和解包.并不包括RPC的实现.但其包括了RPC的定义.如果有以 ...
- canvas绘制自定义的曲线,以椭圆为例,通俗易懂,童叟无欺
本篇文章,将讲述如何通过自定义的曲线函数,使用canvas的方式进行曲线的绘制. 为了通俗易懂,将以大家熟悉的椭圆曲线为例,进行椭圆的绘制.至于其他比较复杂的曲线,用户只需通过数学方式建立起曲线函数, ...