从C++到JSON,存入redis数据库再逆序列化为JAVA。

目录


一 、基本原理.

1.1原理图

Created with Raphaël 2.1.0c++Json-Redis-Json Java

二 、从C++序列化到JSON,存入redis.

1.1环境清单

  1. linux
  2. gcc
  3. redis + hiredis(lib)
  4. cmake、make
  5. codeblocks(或者其他IDE)

1.2开始工作

  1. redis环境搭建
  2. codeblocks(IDE)配置
  3. rapidjson(C++ToJSON)下载
  4. hiredis依赖配置 (为 5. 做准备)
  5. SimpleRedisClient(toRedis)下载
  6. 最终成果

1.2.1 进入redis官网自行配置,或者移步redis入门教程有详细说明
1.2.2 进入codeblocks官网下载,或者在终端安装,完成之后新建一个项目备用

$ sudo apt-get install codeblocks

1.2.3 序列化我们用到的是rapidjson开源项目,当然也可以去JSON官网翻一翻其他开源项目来使用。下面的命令请在workspace里刚才项目的路径下键入

$ git clone https://github.com/miloyip/rapidjson.git
$ cd rapidjson
$ sudo cmake -DCMAKE_INSTALL_PREFIX=/usr/local/include
$ make
$ make install

这有一个例子,倘若可以跑了,说明配置好了。
demo.cpp:

// rapidjson/example/simpledom/simpledom.cpp`
#include <string>
#include <stdlib.h>
#include "rapidjson/document.h"
#include "rapidjson/writer.h"
#include "rapidjson/stringbuffer.h"
#include <iostream>

using namespace rapidjson;

int main() {
    // 1. Parse a JSON string into DOM.
    const char* json = "{\"project\":\"rapidjson\",\"stars\":10}";
    Document d;
    d.Parse(json);

    // 2. Modify it by DOM.
    Value& s = d["stars"];
    s.SetInt(s.GetInt() + 1);

    // 3. Stringify the DOM
    StringBuffer buffer;
    Writer<StringBuffer> writer(buffer);
    d.Accept(writer);

    // Output {"project":"rapidjson","stars":11}
    std::cout << buffer.GetString() << std::endl;
    return 0;
}

1.2.4 hiredis环境配置:直接在终端

$ sudo apt-get install libhiredis-dev

1.2.5 存到redis我们用到的是SimpleRedisClient,同样你也可以去redis客户端翻一翻其他开源项目来使用。下面的命令请在workspace里刚才项目的路径下键入

$ git clone https://github.com/Levhav/SimpleRedisClient.git
$ cd SimpleRedisClient

再进入到对应的redis版本的目录下,把SimpleRedisClient.h拷贝到 刚才demo.cpp同级的目录下。并且在codeblocks中把它导入到项目中。demo使命已经完成,移除demo.cpp(不然会有冲突)
1.2.6 最终成果
final.cpp:


#include "stdlib.h"
#include <stdio.h>
#include "/home/morpheus/CodeBlocks_workspqce/final/SimpleRedisClient.h"//注意路径
#include <iostream>
#include <string>
#include "rapidjson/document.h"
#include "rapidjson/writer.h"
#include "rapidjson/stringbuffer.h"

using namespace std;
using namespace rapidjson;

int main(int argc, char *argv[])
{   
    //toJson
    StringBuffer s;
    Writer<StringBuffer> writer(s);

    writer.StartObject();                       // Between StartObject()/EndObject()

    writer.Key("name");                     // output a key,
    writer.String("gaoyisheng");                // follow by a value.
    writer.Key("age");
    writer.Int(123);                        

    writer.EndObject();             // Between StartObject()/EndObject(),

    std::cout << s.GetString() << std::endl;


    //toRedis
    SimpleRedisClient rc;

    rc.setHost("127.0.0.1");            //redis服务器端口
    rc.setPort(6379);
    rc.auth("");                        //改成你的   链接redis服务器的用户
    rc.LogLevel(0);

    if(!rc)
    {
        printf("Соединение с redis не установлено\n");//没有安装连接redis
        return -1;
    }

    rc.getset("me",s.GetString());//set()方法同样适用,详见SimpleRedisClient代码

    rc.redis_close();
}

1.3 总结归纳

1.3.1 倘若在局域网内通过redis传递,需将redis配置改为 bind 0.0.0.0 ,在final.cpp中将 127.0.0.1 改为 服务器地址。
1.3.2 倘若是下载解压的redis,需自行打开服务器。./redis-server
1.3.3 在导入项目时,需注意路径问题,文件最好放在codeblocks的workspace下!


三 、从redis取出,逆序列化为JAVA.

请移步我同窗的博客,已有详解。
http://blog.csdn.net/qq_33429968/article/details/53045336

四 、声明

小可不才,恭听指正。

*欢迎任何形式的转载,烦请注明装载,保留本段文字。
*本文原文链接 :http://blog.csdn.net/timo1160139211/article/details/53045715

*参考文献:见上述官网。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要从前端获取数据并将其存储到Redis数据库中,您可以使用Java作为后端服务器来处理前端的请求,并使用Redis客户端库连接和操作Redis数据库。以下是一个基本的示例代码: ```java import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; import redis.clients.jedis.JedisPoolConfig; import java.util.Map; public class RedisDataStorage { private static final String REDIS_HOST = "localhost"; // Redis服务器主机 private static final int REDIS_PORT = 6379; // Redis服务器端口 private static final String REDIS_PASSWORD = "your_password"; // Redis密码(如果有的话) private static JedisPool jedisPool; public static void main(String[] args) { // 创建Redis连接池 JedisPoolConfig poolConfig = new JedisPoolConfig(); jedisPool = new JedisPool(poolConfig, REDIS_HOST, REDIS_PORT, 0, REDIS_PASSWORD); // 获取前端传递的数据 String key = "user"; Map<String, String> userData = getFrontendData(); // 存储数据Redis中 try (Jedis jedis = jedisPool.getResource()) { jedis.hmset(key, userData); System.out.println("数据已存储到Redis中:" + userData); } catch (Exception e) { e.printStackTrace(); } // 关闭Redis连接池 jedisPool.close(); } private static Map<String, String> getFrontendData() { // 从前端获取数据的逻辑,此处省略 // 假设返回一个包含键值对的Map对象 // 示例:{ "name": "John", "email": "john@example.com" } // 实际情况下,您需要根据前端的具体数据结构进行处理 } } ``` 在上面的示例中,我们使用Jedis库来连接Redis服务器。首先,创建一个JedisPool对象来管理Redis连接池。然后,使用`getFrontendData`方法模拟从前端获取数据。接下来,使用`hmset`方法将数据存储到Redis的哈希表中。最后,关闭Redis连接池。 请注意,上述代码仅为示例,您需要根据实际情况进行修改和扩展,特别是获取前端数据的逻辑。此外,在生产环境中,建议使用连接池来管理Redis连接,以提高性能和资源利用率。 希望对您有所帮助!如有更多问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值