package com.xxx.common.util;

import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.util.*; /**
* 测试某些非空数据使用
* @author xw
*/
public class MockUtil {
private static double curD = 100.1; private static float curF = 10000.2f; private static int curInt = 1; private static long curL = 1000; private static int curS = 1; private static String[] rs = new String[] { "A", "C", "D", "E", "F", "J", "H", "I", "K", "L", "M", "N", "O", "P", "Q", "R",
"S", "T", "U", "V", "W", "X", "Y", "Z", "a", "c", "d", "e", "f", "j", "h", "i", "k", "l", "m", "n", "o", "p", "q",
"r", "s", "t", "u", "v", "w", "x", "y", "z", "1", "2", "3", "4", "5", "6", "7", "8", "9", "0", "f" }; private static String getFieldName(String methodName) {
String s = "set";
String ups = methodName.toLowerCase();
String key = null;
if (ups.indexOf(s) != -1) {
key = ups.substring(s.length());
}
return (key == null) ? null : key;
} public static <T> T getJavaBean(Class<T> c) { T object = null;
List<Method> allMethods = new ArrayList<Method>();
List<Field> allFields = new ArrayList<Field>();
try {
object = c.newInstance();
Method[] methods = c.getDeclaredMethods();
Field[] fields = c.getDeclaredFields();
allMethods.addAll(Arrays.asList(methods));
allFields.addAll(Arrays.asList(fields));
Class superClass = c.getSuperclass();
while (superClass != null) {
allMethods.addAll(Arrays.asList(superClass.getDeclaredMethods()));
allFields.addAll(Arrays.asList(superClass.getDeclaredFields()));
superClass = superClass.getSuperclass();
}
for (Method m : allMethods) {
if (m.getName().indexOf("set") != -1) {
String field = getFieldName(m.getName());
String type = "string";
for (Field f : allFields) {
if (f.getName().toLowerCase().equals(field)) {
type = f.getType().getSimpleName();
break;
}
}
m.invoke(object, new Object[] { getValue(type) });
}
} } catch (Exception e) {
// e.printStackTrace();
}
return object;
} public static String getRand(int size) {
Random random = new Random();
String rvs = "";
for (int i = 0; i < size; i++) {
int status = random.nextInt(size);
if (status < rs.length && status > 0) {
rvs += rs[status];
}
else {
rvs += "A";
} }
return rvs;
} private static Object getValue(String s) {
Object temp = null;
String st = s.toLowerCase();
Random random = new Random(10010);
if (st.equals("int") || st.equals("integer")) {
temp = curInt;
curInt++;
}
else if (st.equals("long")) {
temp = curL;
curL++;
}
else if (st.equals("string")) {
temp = curS + getRand(6);
curS++;
}
else if (st.equals("double")) {
temp = curD;
curD++;
}
else if (st.equals("float")) {
temp = curF;
curF++;
}
else if (st.equals("boolean")) {
temp = random.nextBoolean();
}
else if (st.equals("date")) {
temp = new Date();
}
return (temp == null) ? null : (temp);
}
}

  mock 数据使用工具

Mock数据使用的Util的更多相关文章

  1. 微信小程序教学第二章(含视频):小程序中级实战教程之预备篇 - 封装网络请求及 mock 数据

    § 封装网络请求及 mock 数据 本文配套视频地址: https://v.qq.com/x/page/i05544fogcm.html 开始前请把 ch2-3 分支中的 code/ 目录导入微信开发 ...

  2. vue-cli项目中怎么mock数据

    在vue项目中, mock数据可以使用 node 的 express模块搭建服务 1. 在根目录下创建 test 目录, 用来存放模拟的 json 数据, 在 test 目录下创建模拟的数据 data ...

  3. json-server mock数据

    前言: 项目开发中,影响项目进程的常常是由于在前后端数据交互的开发流程中停滞,前端完成静态页面的开发后,后端迟迟未给到接口.而现在,我们就可以通过根据后端接口字段,建立一个REST风格的API接口,进 ...

  4. vue-cli项目使用mock数据的方法(借助express)

    前言 现如今前后端分离开发越来越普遍,前端人员写好页面后可以自己模拟一些数据进行代码测试,这样就不必等后端接口,提高了我们开发效率.今天就来分析下前端常用的mock数据的方式是如何实现的. 主体 项目 ...

  5. Vue CLI 3.0脚手架如何在本地配置mock数据

    前后端分离的开发模式已经是目前前端的主流模式,至于为什么会前后端分离的开发我们就不做过多的阐述,既然是前后端分离的模式开发肯定是离不开前端的数据模拟阶段. 我们在开发的过程中,由于后台接口的没有完成或 ...

  6. vue admin mock数据

    搭建脚手架axios访问不到接口:mock数据的问题mock下的index.js设置了默认指向

  7. fiddler安装及mock数据

    1,fiddler安装,解决无法抓到https问题 可用本机的火狐浏览器测试,不行,就fiddler生成证书,拷到火狐里 在firefox中,选项->进入配置界面:高级-> 证书 -> ...

  8. 关于vue-cli创建项目(小白)(2)mock数据

    mock数据,好处,前后端分离,不用等后端的真实接口,就可以用axios(ek sju s 好像这么读,原谅本人总是根据读音写单词)请求数据了. 一,安装所需插件 根据不同需求选择安装环境,mockj ...

  9. nodejs构建mock数据

    Nodejs构建mock数据并通过rest api风格调用接口访问数据 如果我们只有json格式的数据文件,我们想通过访问url方式调用居然数据 确保电脑安装node环境 如果你没有安装好node环境 ...

随机推荐

  1. Android EditText 状态切换

    不可编辑状态 <EditText                     android:id="@+id/ed_newPwd"                     an ...

  2. Win7如何修改文件夹的默认视图,如何把详细信息改为平铺视图

    先任意进入一个文件夹,右击选择平铺视图.   然后点击左上角的组织,文件夹和搜索选项,在文件夹选项的查看中点击"应用到文件夹",然后点击确定,弹出对话框,再确定.   随后再浏览别 ...

  3. docker中的link

    一.查看容器的详细情形 docker inspect 容器id/名称 二.为什么要用link 容器每次重启时,ip都会变动,这不利于前端引用中连接数据库. 三.link docker run -p 8 ...

  4. 微信小程序 (node) warning: possible EventEmitter memory leak detected

    小程序 (node) warning: possible EventEmitter memory leak detected. %d listeners added. Use emitter.setM ...

  5. Vue 作用域插槽

    使用场景:复用子组件的slot,又可以使slot的内容不一样. <!DOCTYPE html> <html lang="zh"> <head> ...

  6. 【Spark】Spark的Standalone模式安装部署

    Spark执行模式 Spark 有非常多种模式,最简单就是单机本地模式,还有单机伪分布式模式,复杂的则执行在集群中,眼下能非常好的执行在 Yarn和 Mesos 中.当然 Spark 还有自带的 St ...

  7. (一)Lucene——基本概念介绍

    1. Lucene是什么 Lucene 是一个基于 Java 的全文信息检索工具包,它不是一个完整的搜索应用程序,而是为你的应用程序提供索引和搜索功能.Lucene 目前是 Apache Jakart ...

  8. StarUML 破解方法

    在安装目录的:StarUML\www\license\node 找到LicenseManagerDomain.js 在 try 前面加上: return { name:"0xcb" ...

  9. Python-PyQt4学习资料汇总

    摘自:http://www.cnblogs.com/coderzh/archive/2009/06/28/1512654.html 官方文档: http://pyqt.sourceforge.net/ ...

  10. 【前端】CSS

    CSS介绍 CSS(Cascading Style Sheet,层叠样式表)定义如何显示HTML元素.l 当浏览器读到一个样式表,它就会按照这个样式表来对文档进行格式化(渲染). CSS语法 CSS实 ...