Tastypie 学习笔记

Tastypie是什么? 运行于Python环境中的 Django web服务器下的 Restful 风格API  (python 类库)

1、安装下面环境或者依赖包到python库(安装过程类似django 在命令行cd 到下载的文件目录中,输入python setup.py install就可以安装了

2、安照之前django教程建立了一个名为blog的app

D:\project\tastypie\mysite\blog\models.py 数据模型文件如下:

from tastypie.utils.timezone import now
from django.contrib.auth.models import User
from django.db import models
from django.utils.text import slugify

# Create your models here.
class Entry(models.Model):
    user = models.ForeignKey(User)
    pub_date = models.DateTimeField(default=now)
    title = models.CharField(max_length=200)
    slug = models.SlugField()#当你看见当下网页url后面出现a-b-c-d-f类似的字符串,就是被slugify了
    body = models.TextField()

    def __str__(self):
        return self.title

    def save(self, *args, **kwargs):
        if not self.slug:
            self.slug = slugify(self.title)[:50]

        return super(Entry,self).save(*args, **kwargs)

3、在blog项目中配置tastypie

D:\project\tastypie\mysite\mysite\settings.py配置文件加入tastypie[非必要的]

# Application definition

INSTALLED_APPS = (
    ‘django.contrib.admin‘,
    ‘django.contrib.auth‘,
    ‘django.contrib.contenttypes‘,
    ‘django.contrib.sessions‘,
    ‘django.contrib.messages‘,
    ‘django.contrib.staticfiles‘,
    ‘blog‘,
    ‘tastypie‘,
)

4、创建API资源

D:\project\tastypie\mysite\blog\api\resources.py(手动创建的目录及文件)

from django.contrib.auth.models import User
from tastypie.authorization import Authorization
from tastypie import fields
from tastypie.resources import ModelResource ,ALL ,ALL_WITH_RELATIONS
from blog.models import Entry

class UserResource(ModelResource):
    class Meta:
        queryset = User.objects.all()
        resource_name = ‘user‘
        excludes = [‘email‘,‘password‘,‘is_active‘,‘is_staff‘,‘is_superuser‘]
        #fields=[‘username‘,‘first_name‘,‘last_name‘,‘last_login‘]
        #allowed_methods = [‘get‘]
        authorization = Authorization()
        filtering={
            ‘username‘:ALL,
        }

class EntryResource(ModelResource):
    user = fields.ForeignKey(UserResource,‘user‘)
    class Meta:
        queryset = Entry.objects.all()
        resource_name = ‘entry‘
        authorization = Authorization()
        filtering = {
            ‘user‘ : ALL_WITH_RELATIONS,
            ‘pub_date‘:[‘exact‘,‘lt‘,‘lte‘,‘gte‘,‘gt‘],
        }

5、url配置

主url配置,D:\project\tastypie\mysite\mysite\urls.py

from django.conf.urls import patterns, include, url
from django.contrib import admin
from tastypie.api import Api
from blog.api.resources import EntryResource,UserResource

v1_api = Api(api_name=‘v1‘)
v1_api.register(UserResource())
v1_api.register(EntryResource())

urlpatterns = patterns(‘‘,
    # Examples:
    (r‘^blog/‘, include(‘blog.urls‘,namespace="blog")),
    (r‘^api/‘, include(v1_api.urls)),
    (r‘^admin/‘, include(admin.site.urls)),
)

子url配置(主要是用来玩ajax调用等会使用),D:\project\tastypie\mysite\blog\urls.py

from django.conf.urls import patterns,url
from blog import views

urlpatterns=patterns(‘‘,
    url(r‘^$‘,views.IndexView.as_view(),name=‘index‘),
)

6、下载个cURL工具加入到环境变量中使用,用于测试链接

7、开始玩API了

1)用命令行输入

curl http://localhost:8000/api/v1/得到如下json内容
{
    "entry": {
        "list_endpoint": "/api/v1/entry/",
        "schema": "/api/v1/entry/schema/"
    },
    "user": {
        "list_endpoint": "/api/v1/user/",
        "schema": "/api/v1/user/schema/"
    }
}

2)输入

curl http://localhost:8000/api/v1/entry/列出所有的json数据

3)下面我们在同个域下面用静态网页加上jquery的ajax来玩

3.1)先加个template文件:D:\project\tastypie\mysite\blog\templates\blog\index.html 记得在setting文件中加路径引用TEMPLATE_DIRS = [os.path.join(BASE_DIR,‘templates‘)]

<!DOCTYPE html> <html lang="en" xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta charset="utf-8" />
    <title></title>

</head>
<body>
    <script type="text/javascript" src="/static/js/jquery-1.8.3.min.js"></script>
<script type="text/javascript" src="/static/js/json2.js"></script>
<script>
    $(document).ready(function () {
        $.ajax({
            url: ‘http://localhost:8000/api/v1/entry/1/‘,
            type: ‘GET‘,
            dataType: ‘json‘,
            success: function (data) {
                console.log(data);
            }
        });
    });
</script>
    </body></html>

3.2)绑定个view:D:\project\tastypie\mysite\blog\views.py

from django.shortcuts import render
from django.views import generic

# Create your views here.
class IndexView(generic.ListView):
    template_name=‘blog/index.html‘
    context_object_name=‘‘

    def get_queryset(self):
        """Return the last five published question"""
        return ‘‘

3.3)前面提到的配置子url:D:\project\tastypie\mysite\blog\urls.py

from django.conf.urls import patterns,url
from blog import views

urlpatterns=patterns(‘‘,
    url(r‘^$‘,views.IndexView.as_view(),name=‘index‘),
)

3.4)好,用Chrome 测试ajax调用,GET方法,输入url http://localhost:8000/blog/   

按F12看log结果

Object {body: "test1", id: 1, pub_date: "2015-01-28T12:14:49", resource_uri: "/api/v1/entry/1/", slug: "test1"…}

3.5)现在看测试,POST方法,注意用了json2类库,js代码改为

        var data = JSON.stringify({
            "title": "Another Post 3",
            "body": "This will prbbly be my 1st post.",
            "pub_date": "2015-01-29T11:07:30",
            "slug": "another-post",
            "user": "/api/v1/user/1/"
        });
        $.ajax({
            url: ‘http://localhost:8000/api/v1/entry/‘,
            type: ‘POST‘,
            contentType: ‘application/json‘,
            data: data,
            dataType: ‘json‘,
            processData: false,
            success: function (data) {
                console.log(data);
            },
            error: function (data) {
                console.log(data);
            }

        });

用浏览器看结果:输入http://localhost:8000/api/v1/entry/?format=json

{"body": "This will prbbly be my 1st post.", "id": 7, "pub_date": "2015-01-29T11:07:30", "resource_uri": "/api/v1/entry/7/", "slug": "another-post", "title": "Another Post 3", "user": "/api/v1/user/1/"} 记录已经POST成功了!

3.6)

PUT 、PATCH 、DELETE,逐个试过可以成功运行!

时间: 2024-10-13 01:15:46

Tastypie 学习笔记的相关文章

vector 学习笔记

vector 使用练习: /**************************************** * File Name: vector.cpp * Author: sky0917 * Created Time: 2014年04月27日 11:07:33 ****************************************/ #include <iostream> #include <vector> using namespace std; int main

Caliburn.Micro学习笔记(一)----引导类和命名匹配规则

Caliburn.Micro学习笔记(一)----引导类和命名匹配规则 用了几天时间看了一下开源框架Caliburn.Micro 这是他源码的地址http://caliburnmicro.codeplex.com/ 文档也写的很详细,自己在看它的文档和代码时写了一些demo和笔记,还有它实现的原理记录一下 学习Caliburn.Micro要有MEF和MVVM的基础 先说一下他的命名规则和引导类 以后我会把Caliburn.Micro的 Actions IResult,IHandle ICondu

jQuery学习笔记(一):入门

jQuery学习笔记(一):入门 一.JQuery是什么 JQuery是什么?始终是萦绕在我心中的一个问题: 借鉴网上同学们的总结,可以从以下几个方面观察. 不使用JQuery时获取DOM文本的操作如下: 1 document.getElementById('info').value = 'Hello World!'; 使用JQuery时获取DOM文本操作如下: 1 $('#info').val('Hello World!'); 嗯,可以看出,使用JQuery的优势之一是可以使代码更加简练,使开

[原创]java WEB学习笔记93:Hibernate学习之路---Hibernate 缓存介绍,缓存级别,使用二级缓存的情况,二级缓存的架构集合缓存,二级缓存的并发策略,实现步骤,集合缓存,查询缓存,时间戳缓存

本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 -----------------------------------------------------------------------------------------------------------------

Activiti 学习笔记记录(三)

上一篇:Activiti 学习笔记记录(二) 导读:上一篇学习了bpmn 画图的常用图形标记.那如何用它们组成一个可用文件呢? 我们知道 bpmn 其实是一个xml 文件

HTML&CSS基础学习笔记8-预格式文本

<pre>标签的主要作用是预格式化文本.被包围在 pre 标签中的文本通常会保留空格和换行符.而文本也会呈现为等宽字体. <pre>标签的一个常见应用就是用来表示计算机的源代码.当然你也可以在你需要在网页中预显示格式时使用它. 会使你的文本换行的标签(例如<h>.<p>)绝不能包含在 <pre> 所定义的块里.尽管有些浏览器会把段落结束标签解释为简单地换行,但是这种行为在所有浏览器上并不都是一样的. 更多学习内容,就在码芽网http://www.

java/android 设计模式学习笔记(14)---外观模式

这篇博客来介绍外观模式(Facade Pattern),外观模式也称为门面模式,它在开发过程中运用频率非常高,尤其是第三方 SDK 基本很大概率都会使用外观模式.通过一个外观类使得整个子系统只有一个统一的高层的接口,这样能够降低用户的使用成本,也对用户屏蔽了很多实现细节.当然,在我们的开发过程中,外观模式也是我们封装 API 的常用手段,例如网络模块.ImageLoader 模块等.其实我们在开发过程中可能已经使用过很多次外观模式,只是没有从理论层面去了解它. 转载请注明出处:http://bl

[原创]java WEB学习笔记48:其他的Servlet 监听器:域对象中属性的变更的事件监听器 (3 个),感知 Session 绑定的事件监听器(2个)

本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 ---------------------------------

java/android 设计模式学习笔记(10)---建造者模式

这篇博客我们来介绍一下建造者模式(Builder Pattern),建造者模式又被称为生成器模式,是创造性模式之一,与工厂方法模式和抽象工厂模式不同,后两者的目的是为了实现多态性,而 Builder 模式的目的则是为了将对象的构建与展示分离.Builder 模式是一步一步创建一个复杂对象的创建型模式,它允许用户在不知道内部构建细节的情况下,可以更精细地控制对象的构造流程.一个复杂的对象有大量的组成部分,比如汽车它有车轮.方向盘.发动机.以及各种各样的小零件,要将这些部件装配成一辆汽车,这个装配过