美文网首页后端
angular2+play-java学习笔记

angular2+play-java学习笔记

作者: avery1 | 来源:发表于2017-12-28 14:11 被阅读0次

    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);

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

    相关文章

      网友评论

        本文标题:angular2+play-java学习笔记

        本文链接:https://www.haomeiwen.com/subject/htvlgxtx.html