Java-IDEA模拟一个Redis服务器,与Redis客户端进行一次简单的交互。默认端口号:6379

本文主要是介绍Java-IDEA模拟一个Redis服务器,与Redis客户端进行一次简单的交互。默认端口号:6379,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先要了解Redis的交互协议。

摘抄:

  1. 简单字符串(Simple Strings): 以 “+” 开头,例如 “+OK\r\n” 表示一个成功的响应。
  2. 错误(Errors): 以 “-” 开头,例如 “-ERR unknown command\r\n” 表示一个错误响应。
  3. 整数(Integers): 以 “:” 开头,例如 “:1000\r\n” 表示整数1000。
  4. 批量字符串(Bulk Strings): 以 “$” 开头,例如 “$6\r\nfoobar\r\n” 表示一个长度为6的字符串 “foobar”。
  5. 数组(Arrays): 以 “*” 开头,例如 “*3\r\n:1\r\n:2\r\n:3\r\n” 表示包含3个整数的数组 [1, 2, 3]。

 最好设置Redis是无密码允许访问。

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.InetSocketAddress;
import java.net.ServerSocket;
import java.net.Socket;
import java.net.SocketAddress;/*** @ Annotation:模拟Redis服务器 port=6379*/
public class RedisHost {/*** 1.客户端连接命令:COMMAND* 2.RedisHost response "OK"* 3.客户端发送命令* 4.RedisHost response "OK"(如果是"set"命令)* 5.客户端发送命令* 6.RedisHost response "value"(如果是"get")命令* @param args*/public static void main(String[] args) {try {byte[] bytes = new byte[1024];ServerSocket server = new ServerSocket();InetSocketAddress address = new InetSocketAddress("127.0.0.1", 6379);server.bind(address);Socket accept = server.accept();InputStream is = accept.getInputStream();//客户端带宽//客户端连接int clientCon = is.read(bytes);System.out.println("客户端连接:" + new String(bytes, 0, clientCon));OutputStream os = accept.getOutputStream();//Redis服务器带宽//Redis回应OKString hostRespCon = "+OK\r\n";os.write(hostRespCon.getBytes());os.flush();System.out.println("客户端与Redis服务器连接成功,Redis服务器响应了:" + hostRespCon);System.out.println("客户端可以继续输入内容");//等待客户端输入。。。。//读取客户端的第一次输入int clientSet = is.read(bytes);String clientStr = new String(bytes, 0, clientSet);System.out.println("客户端第一次输入了:" + clientStr);//Redis对客户端的输入响应+OKString hostRespSet = "+OK\r\n";os.write(hostRespSet.getBytes());os.flush();System.out.println("客户端输入成功,Redis服务器响应了:" + hostRespSet);//客户端再次输入System.out.println("客户端可以继续输入内容");int clientGet = is.read(bytes);String clientGetStr = new String(bytes, 0, clientGet);System.out.println("客户端又输入了:" + clientGetStr);//组装语句String substring = getLastStr(clientStr);//值//Redis响应if (clientGetStr.contains("get")) {if (getLastStr(clientGetStr).equals(getKey(clientStr))){os.write(substring.getBytes());System.out.println("服务器响应了:" + substring);}else {String notExist="*-1\r\n$3\r\nnull\r\n";os.write(notExist.getBytes());System.out.println("客户端输入的键:"+getLastStr(clientGetStr)+"不存在!");}}//释放资源os.flush();is.close();os.close();accept.close();server.close();} catch (IOException e) {e.printStackTrace();}}//从后面开始截取:从最后一个字符"input"开始,截到最后。public static String getLastStr(String input) {return input.substring(input.lastIndexOf("$"));}public static String getKey(String s){return s.substring(s.indexOf(s.substring(s.indexOf("$",6))),s.lastIndexOf("$"));}
}

 

 

这篇关于Java-IDEA模拟一个Redis服务器,与Redis客户端进行一次简单的交互。默认端口号:6379的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1143702

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

禁止平板,iPad长按弹出默认菜单事件

通过监控按下抬起时间差来禁止弹出事件,把以下代码写在要禁止的页面的页面加载事件里面即可     var date;document.addEventListener('touchstart', event => {date = new Date().getTime();});document.addEventListener('touchend', event => {if (new