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. 浅析php中抽象类和接口的概念以及区别[转]

    //抽象类的定义: abstract class ku{ //定义一个抽象类 abstract function kx(); ...... } function aa extends ku{ //实现 ...

  2. Unity5.1 新的网络引擎UNET(九) UNET 官方推荐视频教程

    孙广东  2015.7.14 在新的网络引擎出现之前,Unity提供的是 内置 Raknet网络引擎, 这一次Unity想更新UGUI一样,花了大的手笔更新了, UNET. 原来的旧的网络组件 被提示 ...

  3. 1年内4次架构调整,谈Nice的服务端架构变迁之路

    Nice 本身是一款照片分享社区类型的应用,在分享照片和生活态度的同时可以在照片上贴上如品牌.地点.兴趣等tag. Nice从2013.10月份上线App Store到目前每天2亿PV,服务端架构经过 ...

  4. C#秘密武器之表达式树

    一.表达式树入门 Lambda表达式树很复杂,从概念上很难理解清楚,一句话,表达式树是一种数据结构!这里我们通过下面的这个例子来理解一下表达式树,你就能看个大概: lambda表达式树动态创建方法 s ...

  5. vue - webpack.base.conf.js

    描述:webapck基本配置文件. 为了给开发文件和打包文件(webpack.dev.conf.js|| webpack.prod.conf.js) 提供方便. 'use strict' // 路径 ...

  6. webDriver API——第11部分Remote WebDriver

    The WebDriver implementation. class selenium.webdriver.remote.webdriver.WebDriver(command_executor=' ...

  7. 使用python进行图像处理-调整图片大小

    python有一个图像处理库——PIL,可以处理图像文件.PIL提供了功能丰富的方法,比如格式转换.旋转.裁剪.改变尺寸.像素处理.图片合并等等等等,非常强大. 举个简单的例子,调整图片的大小: im ...

  8. 08-spring学习-annotation配置

    利用annotation配置注入关系 为了更好的解释此类存在的意义,下面通过一段习惯性的开发进行问题的描述,例如: 现在有一个IAdminService服务层,这个服务层要调用的是IAdminDAO和 ...

  9. 利用socket.io+nodejs打造简单聊天室

    代码地址如下:http://www.demodashi.com/demo/11579.html 界面展示: 首先展示demo的结果界面,只是简单消息的发送和接收,包括发送文字和发送图片. ws说明: ...

  10. Linux Load average负载详细解释

    http://tianmaotalk.iteye.com/blog/1027970     Linux Load average负载详细解释   linux查看机器负载