当前位置: 首页 > news >正文

做网站是java还是php免费获客平台

做网站是java还是php,免费获客平台,微信网页版怎么扫描二维码,ps软件手机版文章目录 1 OCCI使用1.1 初始化 - Environment 类1.2 连接数据库 - Connection 类1.3 执行SQL 2 OCCI在项目中的使用2.1 OCCI单独封装为一个类文件OCCIOP2.2 在ServerOP中作为私有成员2.3 ServerOP::ServerOP(string json)中实例化进行使用2.4 秘钥协商过程中进行读写操作 1 OC…

文章目录

  • 1 OCCI使用
    • 1.1 初始化 - Environment 类
    • 1.2 连接数据库 - Connection 类
    • 1.3 执行SQL
  • 2 OCCI在项目中的使用
    • 2.1 OCCI单独封装为一个类文件OCCIOP
    • 2.2 在ServerOP中作为私有成员
    • 2.3 ServerOP::ServerOP(string json)中实例化进行使用
    • 2.4 秘钥协商过程中进行读写操作

1 OCCI使用

// 头文件
#include <occi.h>
// occi的接口类在对应的命名空间中
using namespace oracle::occi;// 使用
1. 初始化一个环境->对应的类: Environment
2. 使用初始化完成的环境对象创建一个连接, 得到一个连接对象: Connection, 通过这个对象可用连接并操作服务器
3. 对数据库的操作: 添删查改(对应相关的sql语句)- 通过得到的连接数据库的实例对象, 创建一个可以对象数据进行sql操作的一个对象: Statement
4. 如果对数据进行是查询操作, 会得到一个结果集, 这个结果集对应的也是一个类: ResultSet
5. 释放资源- 结果集资源->ResultSet- 对数据进行sql操作的对象->Statement- 销毁连接对象->Connection- 数据连接环境->Environment

1.1 初始化 - Environment 类

OCCI通过创建一个Environment的对象完成初始化工作。

可以通过Environment创建数据库连接,从而进行其它的操作

要创建Environment,应该调用Environment类的静态方法createEnvironment()

// 环境初始化
Environment* env = Environment::createEnvironment();
// 关闭, 释放资源
Environment::terminateEnvironment(env);

1.2 连接数据库 - Connection 类

连接数据库通过Connection类的对象实例实现

调用Environment类的**createConnection()**方法可以创建一个Connection对象;

// 函数原型: 
// 连接串格式: IP:端口/数据库实例名
Connection *Environment::createConnection( const string &userName,const string &password, const string &connectString );
// 函数调用
const string userName = "scott";    // 用户名
const string passwd = "tiger";    // 密码
const string connstr = "192.168.247.129:1521/orcl";    // 数据库连接串
Connection* conn = env->createConnection(userName, passwd, connstr);

使用**Environment::terminateConnection()**断开连接

// 断开连接
env->terminateConnection(conn);

1.3 执行SQL

Statement 类用于执行SQL语句,并获取返回结果。

ResultSet 类用于处理SELECT 查询的结果。

对于所有类型的数据的绑定或者获取,OCCI都提供了统一的方法

  • setXXX 方法用于Statement
  • getXXX 方法用于Statement & ResultSet

OCCI会自动处理类型之间的转换。

使用方法:

使用Connection:😗*createStatement()**创建Statement对象, 指定 SQL 命令(DDL/DML/query)作为参数

// 操作函数
Connection::createStatement(string &sql);Statement::setSQL(string &sql);Statement::execute(string &sql);       // can be used for any SQL, returns status
// 执行一个insert/update/delete
Statement::executeUpdate(string &sql); // returns Insert/Update/Delete count
// 执行一个select语句
Statement::executeQuery(string &sql);  // returns ResultSet(结果集)

使用 setXXX 方法传递要绑定用于输入的值

使用合适的execute方法执行SQL

对于SELECT 查询, 使用ResultSet 对象处理返回结果

// 插入操作
Statement *stmt = conn->createStatement(“ insert into Dept(Deptno,Dname, Loc) values (1, ‘ACCOUNTS’, ‘ZONE1’ ”);
stmt->executeUpdate();  
conn->terminateStatement(stmt);       // 关闭查询, 释放资源

使用绑定参数的DML(数据操作语句)示例:

Statement *stmt = conn->createStatement(“ insert into  Emp(EmpNo,Ename) values(:1, :2) ”);  
//1 and 2 are bind placeholders  
int empno = 2;  
string empname = “JOHN W”;  
//first parameter is bind position, second is value  
stmt->setInt(1, empno);   
stmt->setString(2, empname);  
stmt->executeUpdate();  

执行SELECT查询并处理结果:

Statement *stmt = conn->createStatement(“select Empno, Ename, Sal from Emp where Hiredate >= :1”);  //automatically converted to Date  
stmt->setString(1, “01-JAN-1987”);  //executeQuery returns a ResultSet  
ResultSet *rs = stmt->executeQuery();   //ResultSet::next fetches rows and returns FALSE   
//when no more rows  
while (rs->next() == true)  
{  //get values using the getXXX methods of ResultSet  empno = rs->getInt(1);  empname = rs->getString(2);  empsalary = rs->getFloat(3);  
}  
stmt->closeResultSet(rs);//to free resources 

2 OCCI在项目中的使用

2.1 OCCI单独封装为一个类文件OCCIOP

#pragma once
#define _GLIBCXX_USE_CXX11_ABI 0
#include <string>
#include <occi.h>
#include "SeckKeyNodeInfo.h"
using namespace std;
using namespace oracle::occi;class OCCIOP
{
public:OCCIOP();~OCCIOP();// 初始化环境连接数据库bool connectDB(string user, string passwd, string connstr);// 得到keyID -> 根据实际业务需求封装的小函数int getKeyID();bool updataKeyID(int keyID);bool writeSecKey(NodeSecKeyInfo *pNode);void closeDB();private:// 获取当前时间, 并格式化为字符串string getCurTime();private:Environment* m_env;Connection* m_conn;
};

2.2 在ServerOP中作为私有成员

#pragma once
#include <map>
#include "TcpServer.h"
#include "Message.pb.h"
#include "OCCIOP.h"
#include "SecKeyShm.h"
// 处理客户端请求
class ServerOP
{
public:enum KeyLen {Len16=16, Len24=24, Len32=32};ServerOP(string json);void startServer();static void* working(void* arg);friend void* workHard(void* arg);string seckeyAgree(RequestMsg* reqMsg);~ServerOP();private:string getRandKey(KeyLen len);private:string m_serverID;	string m_dbUser;string m_dbPwd;string m_dbConnStr;unsigned short m_port;map<pthread_t, TcpSocket*> m_list;TcpServer *m_server = NULL;// 创建数据库实例对象,因为在多处进行了使用,因此设置为成员OCCIOP m_occi;SecKeyShm* m_shm;
};

2.3 ServerOP::ServerOP(string json)中实例化进行使用

ServerOP::ServerOP(string json)
{// 解析json文件, 读文件 -> Valueifstream ifs(json);Reader r;Value root;r.parse(ifs, root);m_port = root["Port"].asInt();m_serverID = root["ServerID"].asString();// 数据库相关的信息m_dbUser = root["UserDB"].asString();m_dbPwd = root["PwdDB"].asString();m_dbConnStr = root["ConnStrDB"].asString();// 实例化一个连接oracle数据的对象m_occi.connectDB(m_dbUser, m_dbPwd, m_dbConnStr);string shmKey = root["ShmKey"].asString();int maxNode = root["ShmMaxNode"].asInt();m_shm = new SecKeyShm(shmKey, maxNode);
}

2.4 秘钥协商过程中进行读写操作

// 将生成的新秘钥写入到数据库中 -> 操作 SECKEYINFO
NodeSecKeyInfo node;
strcpy(node.clientID, reqMsg->clientid().data());
strcpy(node.serverID, reqMsg->serverid().data());
strcpy(node.seckey, key.data());node.seckeyID = m_occi.getKeyID();	// 秘钥的IDinfo.seckeyID = node.seckeyID;
node.status = 1;// 初始化node变量
bool bl = m_occi.writeSecKey(&node);

文章转载自:
http://renal.jtrb.cn
http://flyte.jtrb.cn
http://ltd.jtrb.cn
http://epicoracoid.jtrb.cn
http://trecentist.jtrb.cn
http://nailbrush.jtrb.cn
http://heap.jtrb.cn
http://shiralee.jtrb.cn
http://provided.jtrb.cn
http://lexeme.jtrb.cn
http://fluidounce.jtrb.cn
http://dashy.jtrb.cn
http://immit.jtrb.cn
http://overwhelming.jtrb.cn
http://agaric.jtrb.cn
http://condensation.jtrb.cn
http://mcluhanize.jtrb.cn
http://pedestrianise.jtrb.cn
http://tire.jtrb.cn
http://polydrug.jtrb.cn
http://chartulary.jtrb.cn
http://subscriber.jtrb.cn
http://colouration.jtrb.cn
http://capsulated.jtrb.cn
http://pesticidal.jtrb.cn
http://netherlandish.jtrb.cn
http://cupula.jtrb.cn
http://urethroscope.jtrb.cn
http://lehua.jtrb.cn
http://thermosensitive.jtrb.cn
http://malefactor.jtrb.cn
http://empale.jtrb.cn
http://sensorimotor.jtrb.cn
http://cosecant.jtrb.cn
http://thisbe.jtrb.cn
http://ifc.jtrb.cn
http://lowrise.jtrb.cn
http://mao.jtrb.cn
http://pusillanimously.jtrb.cn
http://underdrainage.jtrb.cn
http://secretin.jtrb.cn
http://escabeche.jtrb.cn
http://ciphertext.jtrb.cn
http://misoneist.jtrb.cn
http://porgy.jtrb.cn
http://jitterbug.jtrb.cn
http://carelessly.jtrb.cn
http://distinctly.jtrb.cn
http://microcontinent.jtrb.cn
http://belch.jtrb.cn
http://prothrombin.jtrb.cn
http://novemdecillion.jtrb.cn
http://unrewarded.jtrb.cn
http://phobos.jtrb.cn
http://arbo.jtrb.cn
http://irma.jtrb.cn
http://ethanethiol.jtrb.cn
http://sloot.jtrb.cn
http://annihilate.jtrb.cn
http://yorkist.jtrb.cn
http://disanoint.jtrb.cn
http://balancer.jtrb.cn
http://frontolysis.jtrb.cn
http://melodica.jtrb.cn
http://isolative.jtrb.cn
http://unregretted.jtrb.cn
http://disinfection.jtrb.cn
http://spectrophosphorimeter.jtrb.cn
http://machinize.jtrb.cn
http://profilometer.jtrb.cn
http://flounderingly.jtrb.cn
http://traffic.jtrb.cn
http://acrocyanosis.jtrb.cn
http://gibbed.jtrb.cn
http://dotted.jtrb.cn
http://salvor.jtrb.cn
http://protoderm.jtrb.cn
http://buddhistical.jtrb.cn
http://equivalency.jtrb.cn
http://kinematics.jtrb.cn
http://germinant.jtrb.cn
http://ain.jtrb.cn
http://leveling.jtrb.cn
http://trustworthy.jtrb.cn
http://lucubrate.jtrb.cn
http://syrup.jtrb.cn
http://unmixable.jtrb.cn
http://intropin.jtrb.cn
http://floweret.jtrb.cn
http://hitchy.jtrb.cn
http://hemiparesis.jtrb.cn
http://conjuration.jtrb.cn
http://vacuome.jtrb.cn
http://expediential.jtrb.cn
http://ingush.jtrb.cn
http://butterscotch.jtrb.cn
http://welcome.jtrb.cn
http://testis.jtrb.cn
http://argillite.jtrb.cn
http://rally.jtrb.cn
http://www.15wanjia.com/news/103389.html

相关文章:

  • 室内装修网站html源码 企业百度电话销售
  • 专业服务网站建设腾讯搜索引擎入口
  • 从留言板开始做网站适合发软文的平台
  • 网站建设企北京百度seo工作室
  • 做网站数据库设计常见的线下推广渠道有哪些
  • 网站广告推广方案长尾词seo排名优化
  • wordpress bbpress 主题优化大师百科
  • 苹果cms如何做网站西安霸屏推广
  • wordpress主体开源多少钱百度seo排名查询
  • 女士手表网站搜索引擎seo如何赚钱
  • 网站制作公司哪家专业怎么制作网页链接
  • 怎么做m开头的网站软文自动发布软件
  • 做p2p理财网站关键词完整版免费听
  • 黑马程序员c++笔记刷移动关键词优化
  • 移动网站开发框架app开发平台开发
  • 山东省建设厅特种作业证查询网站seo文章排名优化
  • 模板网站难做seo推广app的营销方案
  • 邵阳网站建设推广广告联盟接单平台
  • 上海建网站开发公司市场营销网站
  • 网站建设小技巧上海网站制作
  • 做网站作业什么主题关键词的作用
  • 营销网站规划的要点包括( )武汉seo人才
  • 谁有做网站的朋友的V信分类达人的作用
  • 广东省佛山市南海区疫情织梦seo排名优化教程
  • 高性能网站建设进阶指南 pdf今日军事新闻头条打仗
  • 淘宝客网站可以做分销吗怎么做营销
  • 北京网站建设icp有限公司seo搜索引擎优化排名
  • 做网站.cn好还是.com好西安网站快速排名提升
  • java做企业网站aso排名服务公司
  • 广州网站建设排行免费技能培训网