专栏首页编码小白Angular+servlet java实现前后端数据交互

Angular+servlet java实现前后端数据交互

      每学习一个新知识我都会想到的是用它来实现对数据的CRUD,Angularjs也不例外,而实现CRUD的前提就是前后端数据能够进行交互,下面我就展示一个简易的前后端交互代码

Html+js代码:

<!DOCTYPE html>
<html lang="en" >
<head>
<meta charset="utf-8">
<title>servlet+angularjs数据交互</title>
 <script src="framework/angular-1.3.0.14/angular.js"></script>
  <script src="framework/jquery-1.9.1.js"></script>
</head>

<body ng-app="myApp">
    <div ng-controller="demo">
            <input type="button" value="提交" ng-click="submit()"/>
    </div>
<script>
	var app=angular.module("myApp", [])
	  app.config(['$httpProvider', function($httpProvider) {
	 		$httpProvider.defaults.headers.post["Content-Type"] =
         			"application/x-www-form-urlencoded";
 			 $httpProvider.defaults.
         		 transformRequest.unshift(function(data,headersGetter) {
                var key, result = [];
            	for (key in data) {
                 if (data.hasOwnProperty(key)) {
                     result.push(encodeURIComponent(key) + "="
                            + encodeURIComponent(data[key]));
                 }
             }
             return result.join("&");
        });
}]); 
		app.controller("demo", function($scope,$http) {
            $scope.submit = function () {
                var url = "demo";
                var data = {"name": "你好"};
                $http.post(url, data).success(function (data){
                console.log(data);
            });
            };
    });
</script>
</body>
</html>

Java代码:

package com.whpu;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class Demo extends HttpServlet{
    private static final long serialVersionUID = 1L;
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        doPost(req, resp);
    }
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        String name = req.getParameter("name");
        System.out.println(name);
        PrintWriter pw = resp.getWriter();
        String jsonStr="{\"value\":\"hello\"}";
        pw.println(jsonStr);
    }
}

Web.xml代码:

<?xml version="1.0" encoding="UTF-8"?>
<web-app id="WebApp_ID" version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
    <display-name>AngularJs</display-name>
    <servlet>
        <servlet-name>demo</servlet-name>
        <servlet-class>com.whpu.Demo</servlet-class>
    </servlet>
</web-app>
    <servlet-mapping>
        <servlet-name>demo</servlet-name>
        <url-pattern>/demo</url-pattern>
    </servlet-mapping>

  $http.post(url, data)data是一个json对象的参数,在后台通过request即可获取,然后你就可以进行相关处理,而后台传数据到前台

          PrintWriterpw = resp.getWriter();

          StringjsonStr="{\"value\":\"hello\"}";

          pw.println(jsonStr);

通过这三行代码将{"value":"hello"}这个字符串形式的json放入流中在前台通过回调的

        $http.post(url,data).success(function (data){

               console.log(data);

            });

即可访问data及上面{"value":"hello"}这个字符串,并且angularjs会自动解析成json对象

        至于上面的$httpProvider配置则是设置了一些头部属性,以便正确获取参数并防止乱码。启动服务器后,后台java获取的值是你好而前台获得的是一个json对象

至此前后台交互已经完成.

        备注:1、servlet和Angularjs相关的包注意引入

                   2、小白写博客,不喜勿喷

                   3、有什么更好的建议希望提出来

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • cordova学习二 项目创建

    2.1简单创建          Cmd在指定的自己所想创建项目的路径下执行命令:cordova create MyApp 2.2指定应用名与应用id     ...

    cfs
  • ofbiz初级教程

    本教程是ofbiz 基本应用,它涵盖了OFBiz应用程序开发过程的基本原理。目标是使开发人员熟悉最佳实践,编码惯例,基本控制流程以及开发人员对OFBiz定制所需...

    cfs
  • activiti学习笔记(一) 获取流程配置实例

    activiti获取流程配置实例 流程配置的获取方法api        流程配置的获取共有七种方法,但是只分为三类,一类是根据配置文件路径进行获取、一类是根据...

    cfs
  • 数据可视化|二维统计直方图和三维统计分布图

    二维统计直方图的变量x和y的类型必须是数值型。在x和y轴找到各自的最大值和最小值,使得测定的所有数据都包含在【Xmin,Xmax】,【Ymin,Ymax】之间。...

    黑妹的小屋
  • 【手把手教你】搭建自己的量化分析数据库

    数据是金融量化分析的重要基础,包括股票历史交易数据、上市公司基本面数据、宏观和行业数据等。随着信息流量的日益膨胀,学会获取、查询和加工数据信息变得越来越重要。对...

    Python进阶者
  • Vue.js 快速上手精华梳理-实例

    瑞新
  • DRY原则的一个简单实践

    我们之前就发过一篇相关的文章:https://www.cnblogs.com/powertoolsteam/p/12758496.html 其中也提到了包括DR...

    葡萄城控件
  • Python3实现快速排序、归并排序、堆

    py3study
  • [ASP.NET Core 3框架揭秘] 文件系统[1]:抽象的“文件系统”

    ASP.NET Core应用 具有很多读取文件的场景,比如配置文件、静态Web资源文件(比如CSS、JavaScript和图片文件等)以及MVC应用的View文...

    蒋金楠
  • Qt 制作一个音量回馈样式的进度条效果

    使用 Qt 默认的进度条样式是传统的效果,但是 Qt 提供了强大的 QSS 引擎,提供我们去设置丰富的控件样式,这次是为了模仿一个音量或者声音回馈效果的进度条样...

    我与梦想有个约会

扫码关注云+社区

领取腾讯云代金券