后端开挂,p名称空间注入属性

作者: 新金沙平台  发布:2019-08-09

浅析Java反射机制,浅析java反射

一、什么是反射

  动态获得类的新闻以及动态调用对象的秘籍称为Java的反光(Reflection)机制。反射提供了包装程序集、模块和类别的对象。在Java运行时蒙受中,对于自由二个类的对象,能够通过反射获取这几个类的音讯。

图片 1

二、反射的作用

  Java反射机制允许程序在运作时经过Reflection APIs猎取自由三个已盛名称的class的内部消息,富含modifiers(如public、static等)、superclass(如Object)、实现的interfaces(如Serializable)、田野s(属性)和methods(方法)(但不富含methods定义),可于运维时退换田野(field)s的内容,也可调用methods.

三、Java Reflection API简介

  在JDK中,首要由以下类实现Java反射机制:

    ①Class类:代表三个类;

    ②Field类:代表类的分子变量(属性);

    ③Method类:代表类的不二诀窍;

    ④Constructor类:代表类的构造方法;

    ⑤Array类:提供了动态成立数组,以及寻访数组成分的静态方法;

    以上类中,Class类在java.lang包,别的位于java.lang.reflect包。

  java.lang.Object类(全数类的超类)定义了getClass()方法,任性八个Java对象都足以因而此格局赢得它的class。

  Class类是Reflection API中的焦点类,首要有以下情势:

    ①getName():获取类的名字;

    ②get菲尔德s():获取类中public类型的属性;

    ③getDeclaredFields():获取类的具备属性(包蕴public、protected、default、private);

    ④getMethods():获取类中public类型的艺术;

    ⑤getDeclaredMethods():获取类的具有办法;

    ⑥getMethod(String name,Class[] parameterTypes):获取类的内定方法,name:钦定方法的名字,parameterType:钦点方法的参数类型;

    ⑦getConstrutors():获取类中public类型的构造方法;

    ⑧getConstrutor(Class[] parameterTypes):获取类的钦点构造方法,parameterTypes:钦定构造方法的参数类型;

    ⑨newInstance():通过类默许的不带参数的构造方法创设该类的一个对象;

注:在做客私有属性和私家方法时,要求对走访的个人属性或方法设置setAccessible(true)使被反射的类抑制java的看望检查体制。不然会报IllegalAccessException异常。

一、什么是反射 动态 获取类的消息以及 动态 调用对象的主意称为Java的反射(Reflection)机制。反射提供了...

Spring依照XML配置文件 p名称空间注入属性,springxml

要转移对象并透过名称空间注入属性的类 代码如下:

package com.swift;

public class User {
    private String userName;

    public void setUserName(String userName) {
        this.userName = userName;
    }
    public String fun() {
        return "User's fun is ready." this.userName;
    }
}

XML配置文件写法如下:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:p="http://www.springframework.org/schema/p"
    xsi:schemaLocation="
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<!-- IoC 控制反转 SpringSpring根据XML配置文件生成对象 -->
<bean id="user" class="com.swift.User" p:userName="peach"></bean>
</beans>

p:userName="peach"
p:后是属性的变量名 后面是赋值
约束是xmlns:p="http://www.springframework.org/schema/p"

浮动对象及属性值调用方法,代码如下:

package com.swift;

import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

@WebServlet("/test")
public class TestIOC extends HttpServlet {
    private static final long serialVersionUID = 1L;
    public TestIOC() {
        super();
    }
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        response.getWriter().append("Served at: ").append(request.getContextPath());
        @SuppressWarnings("resource")
        //就是下边这几句了
        ApplicationContext context=new ClassPathXmlApplicationContext("applicationContext.xml");
        User user=(User) context.getBean("user");
        String userInfo=user.fun();
        response.getWriter().println();
        response.getWriter().append(userInfo);
    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request, response);
    }

}

 

p名称空间注入属性,springxml 要转移对象并由此名称空间注入属性的类 代码如下: package com.swift; public class User { priv...

后端开挂:3行代码写出8个接口!,后端3行

无可争辩有为数非常多人会想:

那怎么只怕啊?

就算用大致零配置的SpringBoot,写一个最轻松易行的接口也得有3行代码啊!

    @RequestMapping("test/{request}")
    public String test(@PathVariable String request) {
        return request   ": Hello World";
    }

8个没啥用的Hello World接口就得24行代码了!

那还没算 拼SQL连JDBC 或者 调用ORM库 的代码呢!

更别讲还要写 XML配置 的别的库了!

 

正确,用古板方法就是这样。

得到三个用户:

base_url/get/user

获取一个用户列表:

base_url/get/user/list

获得二个讲评:

base_url/get/comment

获得一个商量列表:

base_url/get/comment/list

...

仅仅是查询,一张表(对应客户端的model)将在五个接口了,

若果再增添增加和删除改,批量改批量删,还可能有总计,那就得有8个接口了!

 

 

那便是说笔者是怎么消除的吧?

一模一样连串型的呼吁都只用八个接口:

增                base_url/post

删(饱含批量)  base_url/delete

改(包含批量)  base_url/put

查(富含列表)  base_url/get

统计             base_url/head

 

用最常用的询问央求比方:

获得七个用户:

base_url/get/

拿到贰个用户列表:

base_url/get/

获取四个讲评:

base_url/get

取得四个商量列表:

base_url/get

 ...

都是用同贰个接口!

 

大家用APIJSON来操作一张表,比如用户表User,代码写3行就够了:

//注册表并添加权限,用默认配置
@MethodAccess
public class User {
//内容一般仅供表字段说明及Android App开发使用,服务端不用的可不写。
}

//Verifier内添加权限
accessMap.put(User.class.getSimpleName(), getAccessMap(User.class.getAnnotation(MethodAccess.class)));

可能能够再定制下POST央浼的剧中人物权限:

@MethodAccess(
  POST = {UNKNOWN, ADMIN} //只允许未登录角色和管理员角色新增User,默认配置是 {LOGIN, ADMIN}
)
public class User {}

 

然后运行下Server工程就可以乞请了:

URL:

表单:

{
    "User": {
        "id": 82001
    }
} 

返回:

{
    "User": {
        "id": 82001,
        "sex": 0,
        "name": "Test",
        "tag": "APIJSON User",
        "head": "http://static.oschina.net/uploads/user/19/39085_50.jpg",
        "contactIdList": [
            82004,
            82021,
            70793
        ],
        "pictureList": [
            "http://common.cnblogs.com/images/icon_weibo_24.png"
        ],
        "date": "2017-02-01 19:21:50.0"
    },
    "code": 200,
    "msg": "success"
}

 

 

上边只是查了三个User,要是大家要查女子用户列表,能够这么:

URL:

表单:

{
    "[]": { //数组
        "User": {
            "sex": 1, //性别为女
            "@column": "id,name" //只需要id,name这两个字段
        }
    }
}

返回:

{
    "[]": [
        {
            "User": {
                "id": 82002,
                "name": "Happy~"
            }
        },
        {
            "User": {
                "id": 82003,
                "name": "Wechat"
            }
        },
        {
            "User": {
                "id": 82005,
                "name": "Jan"
            }
        }
    ],
    "code": 200,
    "msg": "success"
}

 

 

User被多包裹了一层?给数组命名称为 User[] 来去掉呢:

表单:

{
    "User[]": { //提取User
        "User": {
            "sex": 1, //性别为女
            "@column": "id,name" //只需要id,name这两个字段
        }
    }
}

返回:

{
    "User[]": [
        {
            "id": 82002,
            "name": "Happy~"
        },
        {
            "id": 82003,
            "name": "Wechat"
        },
        {
            "id": 82005,
            "name": "Jan"
        }
    ],
    "code": 200,
    "msg": "success"
}

 

还要更进一竿提取名字? User-name[] 满足你:

表单:

{
    "User-name[]": { //提取User.name
        "User": {
            "sex": 1, //性别为女
            "@column": "name" //只需要name这个字段
        }
    }
}

返回:

{
    "User-name[]": [
        "Happy~",
        "Wechat",
        "Jan",
        "Meria",
        "Tommy"
    ],
    "code": 200,
    "msg": "success"
}

 

 

 

但一旦是含多张表关联的数组,就毫无去掉了哦:

表单:

{
    "[]": {
        "Comment": {}, //评论
        "User": {      //发布评论的用户
            "[email protected]": "/Comment/userId" //User.id = Comment.userId
        }
    }
}

返回:

{
    "[]": [
        {
            "Comment": {
                "id": 3,
                "toId": 0,
                "userId": 82002,
                "momentId": 15,
                "date": "2017-02-01 19:20:50.0",
                "content": "This is a Content...-3"
            },
            "User": {
                "id": 82002,
                "sex": 1,
                "name": "Happy~",
                "tag": "iOS",
                "head": "http://static.oschina.net/uploads/user/1174/2348263_50.png?t=1439773471000",
                "contactIdList": [
                    82005,
                    82001,
                    38710
                ],
                "pictureList": [],
                "date": "2017-02-01 19:21:50.0"
            }
        },
        {
            "Comment": {
                "id": 4,
                "toId": 0,
                "userId": 38710,
                "momentId": 470,
                "date": "2017-02-01 19:20:50.0",
                "content": "This is a Content...-4"
            },
            "User": {
                "id": 38710,
                "sex": 0,
                "name": "TommyLemon",
                "tag": "Android&Java",
                "head": "http://static.oschina.net/uploads/user/1218/2437072_100.jpg?t=1461076033000",
                "contactIdList": [
                    82003,
                    82005
                ],
                "pictureList": [
                    "http://static.oschina.net/uploads/user/1218/2437072_100.jpg?t=1461076033000",
                    "http://common.cnblogs.com/images/icon_weibo_24.png"
                ],
                "date": "2017-02-01 19:21:50.0"
            }
        }
    ],
    "code": 200,
    "msg": "success"
}

 

 

再有动态Moment和它的点赞用户列表:

{
    "Moment": {},
    "User[]": {
        "User": {
            "id{}@": "Moment/praiseUserIdList" //id在点赞列表praiseUserIdList内
        }
    }
}

 

好像微信个人资料分界面:

{
    "User": {},
    "Moment[]": { //朋友圈照片列表
        "Moment": {
            "@order":"date-", //按发布时间date倒序排列
            "[email protected]": "User/id"
        }
    }
}

 

看似微信生活圈的动态列表:

{
    "[]": {
        "count": 3, //只要3个
        "page": 2,  //要第2页的
        "Moment": {},
        "User": {
            "[email protected]": "/Moment/userId"
        },
        "Comment[]": {
            "Comment": {
                "[email protected]": "[]/Moment/id"
            }
        }
    }
} 

...

 

轻松结构,大肆内容,大肆组合,

想要什么JSON结构、字段内容、表关联组合查询都足以完全自定义!  

"key[]":{}                                         // 查询数组

"key{}":[1,2,3]                                    // 匹配选项范围

"key{}":"<=10,length(key)>1..."                    // 匹配条件范围

"key()":"function(Type0:value0,Type1:value1...)"   // 远程调用函数

"[email protected]":"key0/key1.../targetKey"                    // 引用赋值

"key$":"SQL搜索表达式"                              // 模糊搜索

"key?":"正则表达式"                                 // 正则匹配

"key ":key指定类型的Object                          // 增加/扩展

"key-":key指定类型的Object                          // 减少/去除 

"name:alias"                                      // 新建别名

"@column":"id,sex,name"                           // 返回字段

"@group":"userId"                                 // 分组方式

"@having":"max(id)>=100"                          // 聚合函数

"@order":"date-,name "                            // 排序方式

 

 

上述都以查询央浼,再试试 增删改 和 总括 :

增:  

{
    "Comment": {
        "userId": 82001,
        "momentId": 15,
        "content": "测试新增评论"
    },
    "tag": "Comment"
}

 

删:  

{
    "Comment": {
        "id": 1510394480987
    },
    "tag": "Comment"
}

 

改:  

{
    "Comment": {
        "id": 22,
        "content": "测试修改评论"
    },
    "tag": "Comment"
}

 

批量删:  

{
    "Comment": {
        "id{}": [1510394480987, 1510394804925]
    },
    "tag": "Comment[]"
}

 

批量改:  

{
    "Comment": {
        "id{}": [22, 114],
        "content": "测试批量修改评论"
    },
    "tag": "Comment[]"
}

 

统计:  

{
    "Comment": {
        "content$": "%测试%" //内容包含 测试 两个字
    }
}

 

 

  

回想下,代码才写了3行,就完毕了富含增删改查等各类操作的8个接口以及这么多样查询!

其实用APIJSON根本就毫无自身写接口!这3行代码其实是为着做权限管理!

像个人博客、非商业的信息资源信息网址这种能够未有权限决定的,

改下全局配置,不做权限校验,那就连一行代码都不用写了!!!**

 

 

APIJSON - 后端超光速开荒框架

图片 2

 

**Github源码及文书档案(右上角点Star帮忙下吧^_^)**

下载客户端(测验服务器地址:

APIJSONClientApp.apk

 

图片 3图片 4

明显有过多少人会想: 那怎么只怕吧? 纵然用差不离零配置的SpringBoot,写一个最简便易行的接口也得有...

本文由新金沙平台发布于新金沙平台,转载请注明出处:后端开挂,p名称空间注入属性

关键词: 新金沙平台