更换了Redis的库
新增了对机器人的操作(redis)
This commit is contained in:
parent
2a06117ec7
commit
d247235ca5
2
pom.xml
2
pom.xml
@ -10,7 +10,7 @@
|
||||
</parent>
|
||||
<groupId>com.yutou</groupId>
|
||||
<artifactId>tools</artifactId>
|
||||
<version>1.0.6</version>
|
||||
<version>1.0.7</version>
|
||||
<name>tools</name>
|
||||
<description>Demo project for Spring Boot</description>
|
||||
|
||||
|
@ -5,7 +5,6 @@ import com.alibaba.fastjson.JSONObject;
|
||||
import com.yutou.tools.mybatis.dao.BilibiliLiveDao;
|
||||
import com.yutou.tools.mybatis.model.BilibiliLive;
|
||||
import com.yutou.tools.mybatis.model.BilibiliLiveExample;
|
||||
import com.yutou.tools.utils.RedisTools;
|
||||
import org.springframework.stereotype.Controller;
|
||||
import org.springframework.util.StringUtils;
|
||||
import org.springframework.web.bind.annotation.RequestMapping;
|
||||
|
29
src/main/java/com/yutou/tools/home/nas/QQBot.java
Normal file
29
src/main/java/com/yutou/tools/home/nas/QQBot.java
Normal file
@ -0,0 +1,29 @@
|
||||
package com.yutou.tools.home.nas;
|
||||
|
||||
import com.alibaba.fastjson.JSONObject;
|
||||
import com.yutou.tools.utils.RedisTools;
|
||||
import org.springframework.stereotype.Controller;
|
||||
import org.springframework.web.bind.annotation.RequestMapping;
|
||||
import org.springframework.web.bind.annotation.ResponseBody;
|
||||
|
||||
@Controller
|
||||
@RequestMapping("/localhome/bot")
|
||||
public class QQBot {
|
||||
|
||||
|
||||
@RequestMapping("send.do")
|
||||
@ResponseBody
|
||||
public String send(String msg){
|
||||
JSONObject json=new JSONObject();
|
||||
try {
|
||||
boolean ret= RedisTools.set(1,"msg_"+System.currentTimeMillis(),msg);
|
||||
json.put("code",0);
|
||||
json.put("msg",ret);
|
||||
}catch (Exception e){
|
||||
e.printStackTrace();
|
||||
json.put("code",-1);
|
||||
json.put("msg",e.getMessage());
|
||||
}
|
||||
return json.toJSONString();
|
||||
}
|
||||
}
|
@ -21,8 +21,6 @@ import java.util.List;
|
||||
|
||||
@Controller
|
||||
public class NasManager {
|
||||
@Resource
|
||||
RedisTools redisTools;
|
||||
@Resource
|
||||
NasAdminAddressDao adminAddressDao;
|
||||
@ResponseBody
|
||||
@ -30,7 +28,7 @@ public class NasManager {
|
||||
public String getAdminAddress(HttpServletRequest request){
|
||||
JSONObject json=new JSONObject();
|
||||
|
||||
String address=redisTools.get("adminAddress");
|
||||
String address=RedisTools.get("adminAddress");
|
||||
if(address==null){
|
||||
json.put("code",-1);
|
||||
json.put("msg","暂未设置管理后台");
|
||||
@ -136,7 +134,7 @@ public class NasManager {
|
||||
try {
|
||||
NasAdminAddress address=adminAddressDao.selectByPrimaryKey(Integer.parseInt(id));
|
||||
if(address!=null){
|
||||
redisTools.set("adminAddress",JSONObject.toJSONString(address));
|
||||
RedisTools.set("adminAddress",JSONObject.toJSONString(address));
|
||||
}
|
||||
json.put("code",0);
|
||||
json.put("msg","ok");
|
||||
|
@ -24,9 +24,6 @@ import java.util.regex.Pattern;
|
||||
public class UpdateIp {
|
||||
private static List<String> keys = new ArrayList<>();
|
||||
public static String nas_ip=null;
|
||||
@Resource
|
||||
RedisTools redisTools;
|
||||
|
||||
/* static {
|
||||
keys.add("nas.yutou233.cn;");
|
||||
keys.add("bt.yutou233.cn;");
|
||||
@ -64,7 +61,7 @@ public class UpdateIp {
|
||||
if (testIp != null) {
|
||||
System.out.println("检测到目标:" + line + " 修改IP " + testIp + " > " + ip);
|
||||
if(isNas){
|
||||
String adminAddress=redisTools.get("adminAddress");
|
||||
String adminAddress=RedisTools.get("adminAddress");
|
||||
if(adminAddress!=null) {
|
||||
JSONObject json=JSONObject.parseObject(adminAddress);
|
||||
line = "proxy_pass http://" +ip+":"+json.getInteger("port")+"/;";
|
||||
@ -100,41 +97,12 @@ public class UpdateIp {
|
||||
JSONObject json = new JSONObject();
|
||||
json.put("code", -1);
|
||||
json.put("msg", "未登录");
|
||||
if (Tools.checkWebLogin(request, redisTools) != 1) {
|
||||
if (Tools.checkWebLogin(request) != 1) {
|
||||
// return json.toJSONString();
|
||||
}
|
||||
updateList();
|
||||
File file = new File("/etc/nginx/nginx.conf");
|
||||
//file = new File("D:\\nginx.conf");
|
||||
if (file.exists()) {
|
||||
String testIp = "0.0.0.0";
|
||||
try {
|
||||
BufferedReader reader = new BufferedReader(new FileReader(file));
|
||||
String line;
|
||||
boolean isIp = false;
|
||||
while ((line = reader.readLine()) != null) {
|
||||
// System.out.println(line.trim().replace("server_name","").replace("upstream","").trim());
|
||||
if (keys.contains(line.trim().replace("server_name", "").replace("upstream", "").replace("{", "").trim())) {
|
||||
isIp = true;
|
||||
}
|
||||
if (isIp) {
|
||||
testIp = testIp(line);
|
||||
if (testIp != null)
|
||||
break;
|
||||
}
|
||||
}
|
||||
reader.close();
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
json.put("code", 0);
|
||||
json.put("msg", "ok");
|
||||
json.put("data", testIp);
|
||||
} else {
|
||||
json.put("code", 0);
|
||||
json.put("msg", "没有找到ip");
|
||||
json.put("data", "0.0.0.0");
|
||||
}
|
||||
json.put("data", nas_ip);
|
||||
return json.toJSONString();
|
||||
}
|
||||
|
||||
|
@ -19,8 +19,6 @@ import java.util.Enumeration;
|
||||
public class APIFilter implements Filter {
|
||||
@Resource
|
||||
UKeyDao keyDao;
|
||||
@Resource
|
||||
RedisTools redisTools;
|
||||
|
||||
@Override
|
||||
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
|
||||
@ -39,18 +37,15 @@ public class APIFilter implements Filter {
|
||||
}
|
||||
}
|
||||
if (cookie != null) {
|
||||
if ("ok".equals(redisTools.get(cookie.getValue()))) {
|
||||
if ("ok".equals(RedisTools.get(cookie.getValue()))) {
|
||||
isCookie = true;
|
||||
}
|
||||
}
|
||||
if (!isToken) {
|
||||
System.out.println("token验证不通过:" + token);
|
||||
} else if (!isCookie) {
|
||||
System.out.println("请求无令牌,拦截");
|
||||
}
|
||||
|
||||
if (!isCookie && !isToken) {
|
||||
//response.sendRedirect("/");
|
||||
if(!request.getRequestURI().contains("/login/")){
|
||||
System.out.println("请求无令牌,拦截");
|
||||
if(!request.getRequestURI().contains("/login/")&&!request.getRequestURI().equals("/favicon.ico")){
|
||||
response.sendRedirect("/");
|
||||
return;
|
||||
}
|
||||
|
@ -12,8 +12,6 @@ import org.springframework.data.redis.core.*;
|
||||
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
|
||||
import org.springframework.data.redis.serializer.StringRedisSerializer;
|
||||
|
||||
@Configuration
|
||||
@EnableCaching
|
||||
public class RedisConfig extends CachingConfigurerSupport {
|
||||
@Bean
|
||||
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
|
||||
|
@ -1,33 +1,137 @@
|
||||
package com.yutou.tools.utils;
|
||||
|
||||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.data.redis.core.RedisTemplate;
|
||||
import org.springframework.data.redis.core.StringRedisTemplate;
|
||||
import org.springframework.stereotype.Component;
|
||||
import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
import java.util.Properties;
|
||||
import java.util.Set;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
import java.util.concurrent.TimeUnit;
|
||||
import redis.clients.jedis.Jedis;
|
||||
|
||||
@Component
|
||||
public class RedisTools {
|
||||
@Resource
|
||||
RedisTemplate<String, String> redisTemplate;
|
||||
private static String host;
|
||||
private static int port;
|
||||
private static int TOKEN_TIMEOUT_DEFAULT=360;
|
||||
|
||||
private RedisTools() {
|
||||
|
||||
public void set(String key, String value) {
|
||||
redisTemplate.opsForValue().set(key, value);
|
||||
}
|
||||
|
||||
public void set(String key, String value, long time) {
|
||||
System.out.println("key=" + key + " value=" + value + " time=" + time);
|
||||
redisTemplate.opsForValue().set(key, value, time, TimeUnit.SECONDS);
|
||||
// 写成静态代码块形式,只加载一次,节省资源
|
||||
static {
|
||||
//Properties properties = PropertyUtil.loadProperties("jedis.properties");
|
||||
//host = properties.getProperty("redis.host");
|
||||
//port = Integer.valueOf(properties.getProperty("redis.port"));
|
||||
host="127.0.0.1";
|
||||
port=6379;
|
||||
}
|
||||
|
||||
public String get(String key) {
|
||||
public static boolean set(int dbIndex,String key,String value){
|
||||
try {
|
||||
return redisTemplate.opsForValue().get(key);
|
||||
Jedis jedis =getRedis();
|
||||
jedis.select(dbIndex);
|
||||
String ret=jedis.set(key,value);
|
||||
System.out.println("Redis set ="+ret);
|
||||
jedis.close();
|
||||
} catch (Exception e) {
|
||||
return null;
|
||||
// TODO: handle exception
|
||||
e.printStackTrace();
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
public static boolean set(String key, String value) {
|
||||
return set(0,key,value);
|
||||
}
|
||||
|
||||
public static boolean set(String key,String value,int timeout) {
|
||||
try {
|
||||
Jedis jedis=getRedis();
|
||||
if(timeout==-1){
|
||||
jedis.set(key,value);
|
||||
}else {
|
||||
jedis.setex(key, timeout, value);
|
||||
}
|
||||
jedis.close();
|
||||
}catch (Exception e) {
|
||||
// TODO: handle exception
|
||||
e.printStackTrace();
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
public static String get(String key,int dbIndex){
|
||||
String value = "-999";
|
||||
Jedis jedis=null;
|
||||
try {
|
||||
jedis = getRedis();
|
||||
jedis.select(dbIndex);
|
||||
value = jedis.get(key);
|
||||
jedis.close();
|
||||
} catch (Exception e) {
|
||||
// TODO: handle exception
|
||||
// e.printStackTrace();
|
||||
}finally {
|
||||
if(jedis!=null)
|
||||
jedis.close();
|
||||
}
|
||||
return value;
|
||||
}
|
||||
public static String get(String key) {
|
||||
return get(key,0);
|
||||
}
|
||||
public static boolean remove(String key) {
|
||||
Jedis jedis=getRedis();
|
||||
Long i=jedis.del(key);
|
||||
jedis.close();
|
||||
if(i>0) {
|
||||
return true;
|
||||
}else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
public static void removeLoginState(String uid) {
|
||||
Jedis jedis=getRedis();
|
||||
Set<String> keys=jedis.keys("*");
|
||||
for (String string : keys) {
|
||||
if(string.equals(uid)) {
|
||||
jedis.del(string);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
public static String ping() {
|
||||
Jedis jedis=getRedis();
|
||||
String tmp=jedis.ping();
|
||||
jedis.close();
|
||||
return tmp;
|
||||
}
|
||||
public static boolean exists(String key,String value) {
|
||||
Jedis jedis=getRedis();
|
||||
boolean flag=value.equals(jedis.get(key));
|
||||
jedis.close();
|
||||
return flag;
|
||||
}
|
||||
public static Jedis getRedis() {
|
||||
return new Jedis(host,port);
|
||||
}
|
||||
private static class PropertyUtil {
|
||||
|
||||
// 加载property文件到io流里面
|
||||
public static Properties loadProperties(String propertyFile) {
|
||||
Properties properties = new Properties();
|
||||
try {
|
||||
InputStream is = PropertyUtil.class.getClassLoader().getResourceAsStream(propertyFile);
|
||||
if (is == null) {
|
||||
is = PropertyUtil.class.getClassLoader().getResourceAsStream(propertyFile);
|
||||
}
|
||||
properties.load(is);
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
return properties;
|
||||
}
|
||||
}
|
||||
public static void main(String[] args) {
|
||||
String str= "\"aaa\"";
|
||||
str=str.replaceAll("\"aaa\"", "0");
|
||||
}
|
||||
}
|
||||
|
@ -1,6 +1,7 @@
|
||||
package com.yutou.tools.utils;
|
||||
|
||||
import com.alibaba.fastjson.JSONArray;
|
||||
import com.yutou.tools.nas.UpdateIp;
|
||||
import org.springframework.web.multipart.MultipartFile;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
@ -20,6 +21,7 @@ import java.util.Random;
|
||||
public class Tools {
|
||||
/**
|
||||
* 设置Cookie
|
||||
*
|
||||
* @param response
|
||||
* @param key
|
||||
* @param value
|
||||
@ -34,8 +36,10 @@ public class Tools {
|
||||
response.addCookie(cookie);
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取Cookie
|
||||
*
|
||||
* @param request
|
||||
* @param key
|
||||
* @return
|
||||
@ -54,8 +58,10 @@ public class Tools {
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* 删除Cookie
|
||||
*
|
||||
* @param request
|
||||
* @param response
|
||||
* @param key
|
||||
@ -73,6 +79,7 @@ public class Tools {
|
||||
}
|
||||
return "ok";
|
||||
}
|
||||
|
||||
public static void sendServer(String title, String msg) {
|
||||
try {
|
||||
System.out.println("title=" + title + " msg=" + msg);
|
||||
@ -83,6 +90,10 @@ public class Tools {
|
||||
int i = inputStream.read();
|
||||
inputStream.close();
|
||||
connection.disconnect();
|
||||
if (UpdateIp.nas_ip != null) {
|
||||
connection = (HttpURLConnection) new URL("http://" + UpdateIp.nas_ip + ":8000/localhome/bot/send.do?msg=" + URLEncoder.encode((title + "\n" + msg), "UTF-8") + "&token=zIrsh9TUZP2lfRW753PannG49E7VJvor").openConnection();
|
||||
connection.connect();
|
||||
}
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
@ -90,12 +101,14 @@ public class Tools {
|
||||
|
||||
/**
|
||||
* 获取项目路径
|
||||
*
|
||||
* @param request
|
||||
* @return
|
||||
*/
|
||||
public static String getPath(HttpServletRequest request) {
|
||||
return request.getServletContext().getRealPath("/") + "/";
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取客户端IP
|
||||
*
|
||||
@ -115,13 +128,12 @@ public class Tools {
|
||||
}
|
||||
return ip;
|
||||
}
|
||||
|
||||
/**
|
||||
* N以内的不重复随机数
|
||||
*
|
||||
* @param min
|
||||
* 最小值
|
||||
* @param max
|
||||
* 最大值
|
||||
* @param min 最小值
|
||||
* @param max 最大值
|
||||
* @param n
|
||||
* @return
|
||||
*/
|
||||
@ -148,10 +160,11 @@ public class Tools {
|
||||
}
|
||||
return result;
|
||||
}
|
||||
public static int checkWebLogin(HttpServletRequest request,RedisTools redisTools){
|
||||
|
||||
public static int checkWebLogin(HttpServletRequest request) {
|
||||
JSONArray array = new JSONArray();
|
||||
if(redisTools.get("bean")!=null){
|
||||
array=JSONArray.parseArray(redisTools.get("bean"));
|
||||
if (RedisTools.get("bean") != null) {
|
||||
array = JSONArray.parseArray(RedisTools.get("bean"));
|
||||
}
|
||||
if (array.contains(Tools.getRemoteAddress(request))) {
|
||||
System.out.println("IP已被封禁");
|
||||
@ -161,11 +174,12 @@ public class Tools {
|
||||
if (cookie == null) {
|
||||
return -1;
|
||||
}
|
||||
if (redisTools.get(cookie.getValue()).equals("ok")) {
|
||||
if (RedisTools.get(cookie.getValue()).equals("ok")) {
|
||||
return 1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
public static String get(String url) {
|
||||
try {
|
||||
HttpURLConnection connection = (HttpURLConnection) new URL(url).openConnection();
|
||||
@ -183,13 +197,12 @@ public class Tools {
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* 保存上传的文件
|
||||
*
|
||||
* @param path
|
||||
* 路径
|
||||
* @param file
|
||||
* 文件
|
||||
* @param path 路径
|
||||
* @param file 文件
|
||||
* @return
|
||||
* @throws Exception
|
||||
*/
|
||||
|
@ -19,8 +19,6 @@ import java.util.UUID;
|
||||
|
||||
@Controller
|
||||
public class userController {
|
||||
@Resource
|
||||
RedisTools redisTools;
|
||||
|
||||
@RequestMapping("/login/check.do")
|
||||
@ResponseBody
|
||||
@ -29,8 +27,8 @@ public class userController {
|
||||
json.put("code", -1);
|
||||
json.put("msg", "未登录");
|
||||
JSONArray array = new JSONArray();
|
||||
if (redisTools.get("ban") != null) {
|
||||
array = JSONArray.parseArray(redisTools.get("ban"));
|
||||
if (RedisTools.get("ban") != null) {
|
||||
array = JSONArray.parseArray(RedisTools.get("ban"));
|
||||
}
|
||||
if (array.contains(Tools.getRemoteAddress(request))) {
|
||||
json.put("code", -2);
|
||||
@ -42,7 +40,7 @@ public class userController {
|
||||
if (cookie == null) {
|
||||
return json.toJSONString();
|
||||
}
|
||||
if ("ok".equals(redisTools.get(cookie.getValue()))) {
|
||||
if ("ok".equals(RedisTools.get(cookie.getValue()))) {
|
||||
json.put("code", 0);
|
||||
json.put("msg", "登录成功");
|
||||
return json.toJSONString();
|
||||
@ -56,8 +54,8 @@ public class userController {
|
||||
@ResponseBody
|
||||
public String captcha(HttpServletRequest request) {
|
||||
JSONArray array = new JSONArray();
|
||||
if (redisTools.get("ban") != null) {
|
||||
array = JSONArray.parseArray(redisTools.get("ban"));
|
||||
if (RedisTools.get("ban") != null) {
|
||||
array = JSONArray.parseArray(RedisTools.get("ban"));
|
||||
}
|
||||
if (array.contains(Tools.getRemoteAddress(request))) {
|
||||
|
||||
@ -69,9 +67,9 @@ public class userController {
|
||||
for (int value : captcha) {
|
||||
cc += value;
|
||||
}
|
||||
redisTools.set("login", cc, 5 * 60 * 1000);
|
||||
RedisTools.set("login", cc, 5 * 60 * 1000);
|
||||
String token=UUID.randomUUID().toString().replace("-","");
|
||||
redisTools.set(token,Tools.getRemoteAddress(request),10 * 60 * 1000);
|
||||
RedisTools.set(token,Tools.getRemoteAddress(request),10 * 60 * 1000);
|
||||
String url="http://tools.yutou233.cn/login/ban.do?token="+token;
|
||||
Tools.sendServer("管理后台登录验证码", "本次登录验证码为:" + cc
|
||||
+ ",登录IP:" + Tools.getRemoteAddress(request)
|
||||
@ -81,14 +79,14 @@ public class userController {
|
||||
@RequestMapping("/login/ban.do")
|
||||
@ResponseBody
|
||||
public String banIp(String token){
|
||||
String ip=redisTools.get(token);
|
||||
String ip=RedisTools.get(token);
|
||||
if(ip!=null){
|
||||
JSONArray array = new JSONArray();
|
||||
if (redisTools.get("ban") != null) {
|
||||
array = JSONArray.parseArray(redisTools.get("bean"));
|
||||
if (RedisTools.get("ban") != null) {
|
||||
array = JSONArray.parseArray(RedisTools.get("bean"));
|
||||
}
|
||||
array.add(ip);
|
||||
redisTools.set("ban",array.toJSONString());
|
||||
RedisTools.set("ban",array.toJSONString());
|
||||
return "已封禁";
|
||||
}
|
||||
return "ERROR";
|
||||
@ -98,10 +96,10 @@ public class userController {
|
||||
@ResponseBody
|
||||
public String login(HttpServletResponse response, String code) {
|
||||
JSONObject json = new JSONObject();
|
||||
if (redisTools.get("login").equals(code.trim())) {
|
||||
if (RedisTools.get("login").equals(code.trim())) {
|
||||
String uuid = UUID.randomUUID().toString();
|
||||
Tools.setCookie(response, "user", uuid.replace("-", ""), 30 * 24 * 60 * 60);
|
||||
redisTools.set(uuid.replace("-", ""), "ok", 30 * 24 * 60 * 60);
|
||||
RedisTools.set(uuid.replace("-", ""), "ok", 30 * 24 * 60 * 60);
|
||||
json.put("code", 0);
|
||||
json.put("msg", "登录成功");
|
||||
return json.toJSONString();
|
||||
@ -119,8 +117,8 @@ public class userController {
|
||||
json.put("code", -1);
|
||||
json.put("msg", "退出失败");
|
||||
if (cookie != null) {
|
||||
if ("ok".equals(redisTools.get(cookie.getValue()))) {
|
||||
redisTools.set(cookie.getValue(), "ok", 1);
|
||||
if ("ok".equals(RedisTools.get(cookie.getValue()))) {
|
||||
RedisTools.set(cookie.getValue(), "ok", 1);
|
||||
Tools.deleteCookie(request, response, "user");
|
||||
json.put("code", 0);
|
||||
json.put("msg", "退出成功");
|
||||
|
Loading…
Reference in New Issue
Block a user