后端

angular2+play-java学习笔记

2017-12-28  本文已影响0人  avery1

1、paly-java    sbt命令行

Using the SBT console

进入项目路径执行 sbt

compile

-jvm-debug 9999

run

2、使用[(noModle)]报错

使用[(ngModel)]需要导入FormsModel

3、简单的登录注册Md5加密

注册的时候Md5加密存入数据库,登录的时候转Md5去验证。完全前端实现。

      下载安装Md5

npm install ts-md5 --save

      引入模块

import { Md5 } from 'ts-md5/dist/md5';

然后直接使用就可以了

Md5.hashStr(/*密码*/)

4、获取当前request()

在请求方法里直接用request()

或者在工具类里使用Context获取

5、JWT

Json Web Token 的Java使用 (JJWT)

什么是 JWT -- JSON WEB TOKEN

Bearer Token

http协议基本认证 Authorization

JWT/JJWT JSON WEB TOKEN介绍和使用

JWT

JWT Authentication with Play Framework

build.sbt里添加配置

libraryDependencies ++= Seq(

    "mysql" % "mysql-connector-java" % "5.1.41",

    "io.jsonwebtoken" % "jjwt" % "0.7.0"

)

然后登录成功生成jwt,这里secret  key是写死的字符串‘asd’,当然是需要我们的取写方法生成的,这个key也是我们用来获取jwt验证的时候的依据。这里只是实现里最简单的jwt的生成

package utils;

import io.jsonwebtoken.Jwts;

import io.jsonwebtoken.SignatureAlgorithm;

import java.util.Date;

import org.apache.commons.lang3.time.DateUtils;

import play.libs.Json;

import com.fasterxml.jackson.databind.node.ObjectNode;

public class JwtUtils {

      public static ObjectNode generateJwt(String nickName, String tel) {

                  Date now = new Date();

                 Date expires = DateUtils.addMinutes(now, 5);

                String token = Jwts.builder().claim("nickName", nickName).claim("tel",      tel).setIssuedAt(now).setExpiration(expires).setSubject(nickName).signWith(SignatureAlgorithm.HS256, "asdf").compact();

               ObjectNode json = Json.newObject();

               json.put("token", token);

               json.put("subject", nickName);

               json.put("tel", tel);

               return json;

     }

}

我们成功生成并返回到客户端的token

下面就是进行用户验证的时候携带jwt到服务器端验证。

客户端发请求携带jwt,在请求里添加

服务器端处理使用Authenticator,前面写了生成jwt的方法,这里在写一个获取jwt的方法。

我们在使用Authenticator进行权限控制

创建Authenticator.java

在这个类里重写重写getUsername和onUnauthorized方法

getUsername返回null的时候认为认证失败,没有权限。

这时候在需要进行此权限控制的地方添加注解即可。

最后再把key配置到配置文件里

在java类里使用如官网所说

或者

然后使用的时候直接config.getString("play.crypto.secret")即可

6、java实现简单的base64编码

Java 8实现BASE64编解码

7、Ebean的增删改查

利用find

创建一个空的类,利用set设置完了,执行Ebean的save即可

User user = new User();

user.setNickName(json.get("nickName").asText());

user.setTel(json.get("tel").asText());

Ebean.save(user);

查,利用find的query,findById,where等

List Users = User.find.all();

删除,查找到相应的数据,执行Ebean的delete即可

Article article = Article.find.byId(id);

Ebean.delete(article);

改,查找到对应的数据,执行set,然后执行Ebean.update()

        Long id = json.get("id").asLong();

        String title = json.get("title").asText();

        String content = json.get("content").asText();

        Article article = Article.find.byId(id);

        article.setTitle(title);

        article.setContent(content);

        Ebean.update(article);

8、联表查询

文章根据用户id联表到用户表,多对一

在实体类里添加联表manytoone声明

然后在添加文章的set方法要改下了

       User user = User.find.byId(userId);

        article.setUser(user);

然后页面上获取出来的就可以用了

上一篇下一篇

猜你喜欢

热点阅读