django实现前后台交互实例


Posted in Python onAugust 07, 2017

本文介绍了django实现前后台交互实例,分享给大家,希望对大家有所帮助

准备工作:

前端框架:AngularJS+bootstap

数据库:sqlite3

前端代码:
index.html

<!DOCTYPE html> 
<html> 
  <head> 
    <link href="/WebApi/scripts/bootstrap/dist/css/bootstrap.min.css" rel="external nofollow" rel="stylesheet" type="text/css" /> 
    <script type="text/javascript" src="/WebApi/scripts/angular/angular.min.js"></script> 
    <script type="text/javascript" src="/WebApi/controller/controller.js"></script> 
    <script type="text/javascript" src="/WebApi/service/service.js"></script> 
    <title>hello</title> 
  </head> 
  <body ng-app="myApp" ng-controller="myCtrl"> 
    <h2>hello world!</h2> 
     
<!--   <form role="form"> --> 
    <table> 
      <tr> 
        <td> 
          <div class="form-group"> 
            <input type="text" class="form-control" id="name"  
          placeholder="请输入用户名" ng-model="username"> 
          </div> 
        </td> 
      </tr> 
      <tr> 
        <td> 
          <div class="form-group"> 
            <input type="passwd" class="form-control" id="name"  
          placeholder="请输入密码" ng-model="password"> 
          </div> 
        </td> 
      </tr> 
      <tr> 
        <td> 
          <button type="button" class="btn btn-primary" ng-click="my_submit()">保存</button> 
        </td> 
      </tr> 
    </table> 
<!--   </form> 
 --> 
 
    <p class="text-danger">[[ result ]]</p> 
  </body> 
</html>

controller.js

var app = angular.module("myApp", []); 
app.config( 
  function($interpolateProvider) { 
    $interpolateProvider.startSymbol('[['); 
    $interpolateProvider.endSymbol(']]'); 
  })  
  .config(['$httpProvider', function($httpProvider) { 
    $httpProvider.defaults.xsrfCookieName = 'csrftoken'; 
    $httpProvider.defaults.xsrfHeaderName = 'X-CSRFToken'; 
}]); 
app.controller("myCtrl", ["$scope", "service", function($scope, service) { 
  $scope.result = ""; 
  $scope.my_submit = function() { 
    console.log($scope.username); 
    console.log($scope.password); 
    service.do_save_info($scope.username, $scope.password, function(response){ 
      console.log(response); 
      $scope.result = response.result; 
    }); 
  }; 
}]);

service.js

app.service("service", ["$http", function($http) { 
  this.do_save_info = function(username, password, callback) { 
    $http({ 
      method: 'POST', 
      url: '/do_save_info', 
      data: { 
        'username': username, 
        'password': password 
      }, 
      headers: {'Content-Type': undefined}, 
    }).success(function(response){ 
      callback(response); 
    }); 
  }; 
}]);

后端代码:

urls.py

from django.conf.urls import patterns, include, url 
 
urlpatterns = patterns('app.views', 
  url(r'^index$', 'index'), 
  url(r'^/index$', 'index'), 
  url(r'^$', 'index'), 
  url(r'^/$', 'index'), 
  url(r'^do_save_info$', 'do_save_info'), 
)

views.py

from django.shortcuts import render_to_response 
from django.template import RequestContext 
from django.http import HttpResponse 
from django.views.decorators.csrf import ensure_csrf_cookie, csrf_exempt 
import json 
import models 
 
# Create your views here. 
@ensure_csrf_cookie 
def index(request): 
  return render_to_response('static/index.html', 
    context_instance=RequestContext(request)) 
 
def do_save_info(request): 
  result = {'result':'save success'} 
  try: 
    data = json.loads(request.body) 
    username = data.get("username", None) 
    password = data.get("password", None) 
    models.do_save_info(username, password) 
  except Exception, e: 
    result['result'] = 'save error' 
  return HttpResponse(json.dumps(result))

models.py

#!/bin/python 
# -*- coding: utf-8 -*- 
 
import os 
import sys 
import sqlite3 
 
def do_save_info(username, password): 
  db_path = os.path.normpath('/home/zhubao/Code/django_code/hello/db.sqlite3') 
  try: 
    conn = sqlite3.connect(db_path) 
    sql = "insert into t_user(username, password) values('%s', '%s')" % (username, password) 
    conn.execute(sql) 
    conn.commit() 
    conn.close() 
    print 'save success...' 
  except Exception, e: 
    print '------', str(e) 
    try: 
      conn.close() 
    except Exception, e: 
      pass

t_user表结构:

create table t_user(username varchar(255), password varchar(255));

页面演示:

刚打开页面如下:

django实现前后台交互实例

输入数据,点击保存:

django实现前后台交互实例

后台查看数据库:

django实现前后台交互实例

可以看到,已经保存在数据库里面了。

这只是个小示例,在此不考虑页面排版和安全性问题。。。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
用Python从零实现贝叶斯分类器的机器学习的教程
Mar 31 Python
python获取外网ip地址的方法总结
Jul 02 Python
Python读取文件内容的三种常用方式及效率比较
Oct 07 Python
python实现电脑自动关机
Jun 20 Python
解决pandas .to_excel不覆盖已有sheet的问题
Dec 10 Python
Python基础之条件控制操作示例【if语句】
Mar 23 Python
Python 使用 attrs 和 cattrs 实现面向对象编程的实践
Jun 12 Python
pytorch读取图像数据转成opencv格式实例
Jun 02 Python
Python如何生成xml文件
Jun 04 Python
Python使用sys.exc_info()方法获取异常信息
Jul 23 Python
PyCharm 2020.2 安装详细教程
Sep 25 Python
详解BeautifulSoup获取特定标签下内容的方法
Dec 07 Python
python扫描proxy并获取可用代理ip的实例
Aug 07 #Python
python的多重继承的理解
Aug 06 #Python
python中 chr unichr ord函数的实例详解
Aug 06 #Python
Python实现读取邮箱中的邮件功能示例【含文本及附件】
Aug 05 #Python
Python实现将Excel转换为json的方法示例
Aug 05 #Python
Python实现抓取网页生成Excel文件的方法示例
Aug 05 #Python
Python基于Socket实现的简单聊天程序示例
Aug 05 #Python
You might like
PHP 5.3新增魔术方法__invoke概述
2014/07/23 PHP
PHP中的reflection反射机制测试例子
2014/08/05 PHP
php post大量数据时发现数据丢失问题解决方法
2015/06/20 PHP
Windows2003下php5.4安装配置教程(Apache2.4)
2016/06/30 PHP
PHP实现对二维数组某个键排序的方法
2016/09/14 PHP
PHP mysqli事务操作常用方法分析
2017/07/22 PHP
php5.5使用PHPMailer-5.2发送邮件的完整步骤
2018/10/14 PHP
PHP的PDO预处理语句与存储过程
2019/01/27 PHP
url 编码 js url传参中文乱码解决方案
2010/04/11 Javascript
在chrome浏览器中,防止input[text]和textarea在聚焦时出现黄色边框的解决方法
2011/05/24 Javascript
用最通俗易懂的代码帮助新手理解javascript闭包 推荐
2012/03/01 Javascript
fixedBox固定div漂浮代码支持ie6以上大部分主流浏览器
2014/06/26 Javascript
jQuery超精致图片轮播幻灯片特效代码分享
2015/09/10 Javascript
在JavaScript中如何解决用execCommand(
2015/10/19 Javascript
angularjs表格分页功能详解
2016/01/21 Javascript
深入学习AngularJS中数据的双向绑定机制
2016/03/04 Javascript
使用jQuery.form.js/springmvc框架实现文件上传功能
2016/05/12 Javascript
最棒的Angular2表格控件
2016/08/10 Javascript
vue 搭建后台系统模块化开发详解
2019/05/01 Javascript
小程序实现上传视频功能
2020/08/18 Javascript
uniapp电商小程序实现订单30分钟倒计时
2020/11/01 Javascript
DJANGO-ALLAUTH社交用户系统的安装配置
2014/11/18 Python
Python基于socket实现简单的即时通讯功能示例
2018/01/16 Python
Python3直接爬取图片URL并保存示例
2019/12/18 Python
django有哪些好处和优点
2020/09/01 Python
详解matplotlib绘图样式(style)初探
2021/02/03 Python
html5是什么_动力节点Java学院整理
2017/07/07 HTML / CSS
阿里健康大药房:阿里自营网上药店
2017/08/01 全球购物
小学少先队活动方案
2014/02/18 职场文书
竞选班干部演讲稿100字
2014/08/20 职场文书
2014最新开业庆典策划方案(5篇)
2014/09/15 职场文书
2014小学数学教研组工作总结
2014/12/06 职场文书
公司人事任命通知
2015/04/20 职场文书
2015年世界急救日宣传活动方案
2015/05/06 职场文书
二婚主持词
2015/06/30 职场文书
2016感恩父亲节主题广播稿
2015/12/18 职场文书