亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? sasql.c.bak

?? cygwin環境編譯,saac登陸服務端,石器2最新代碼
?? BAK
字號:
#define _SASQL_C_#include "version.h"#ifdef _SASQL//新添加#include "main.h"#include <windows.h>#include <w32api/sql.h>#include <w32api/sqlext.h>HENV henv = SQL_NULL_HENV;HDBC hdbc = SQL_NULL_HDBC;HSTMT hstmt = SQL_NULL_HSTMT;RETCODE rc;	SQLCHAR sid[16]; 	SQLCHAR sps[16]; 	SQLINTEGER err;typedef struct tagConfig{    char    SQL_DSN[16];     char    SQL_USER[16];	  char	  SQL_PASSWORD[16];    char    SQL_INFOTABLE[16];    		char    SQL_LOCK[16];   				char    SQL_RegTime[16]; 				char    SQL_LoginTime[16]; 				char    SQL_OnlineName[16]; 		}Config;Config config;int AUTOREG;int USEMSSQL;void check_return (RETCODE rc,HENV henv,HDBC hdbc,HSTMT hstmt );static int readConfig( char *path ){    char buf[255];    FILE *fp;    fp = fopen( path , "r" );    if( fp == NULL ){ return -2; }    while( fgets( buf , sizeof( buf ) , fp )){        char command[255];        char param[255];        chop(buf);                easyGetTokenFromString( buf , 1 , command , sizeof( command ));        easyGetTokenFromString( buf , 2 , param , sizeof( param ));				if( strcmp( command , "USEMSSQL" ) == 0 ){        		USEMSSQL = atoi( param );        		if(USEMSSQL==0)break;      	}        if( strcmp( command , "SQL_DSN" ) == 0 ){            snprintf( config.SQL_DSN , sizeof( config.SQL_DSN) , param) ;            log("數據庫 DSN:%s\n",config.SQL_DSN);		 } else if( strcmp( command , "SQL_USER" ) == 0 ){            snprintf( config.SQL_USER , sizeof( config.SQL_USER) , param) ;				  	log("登陸數據庫賬號名:%s\n",config.SQL_USER);        } else if( strcmp( command , "SQL_PASSWORD" ) == 0 ){            snprintf( config.SQL_PASSWORD , sizeof( config.SQL_PASSWORD) , param) ;				  	log("登陸數據庫密碼:%s\n",config.SQL_PASSWORD);        } else if( strcmp( command , "SQL_INFOTABLE" ) == 0 ){            snprintf( config.SQL_INFOTABLE , sizeof( config.SQL_INFOTABLE) , param) ;				  	log("人物信息表:%s\n",config.SQL_INFOTABLE);        } else if( strcmp( command , "SQL_LOCK" ) == 0 ){            snprintf( config.SQL_LOCK , sizeof( config.SQL_LOCK) , param) ;						log("鎖定賬號表:%s\n",config.SQL_LOCK);        } else if( strcmp( command , "SQL_REGTIME" ) == 0 ){            snprintf( config.SQL_RegTime , sizeof( config.SQL_RegTime) , param) ;						log("注冊時間:%s\n",config.SQL_RegTime);				} else if( strcmp( command , "AUTOREG" ) == 0 ){        		AUTOREG = atoi( param );        		if(AUTOREG){        			log("開放自動注冊:YES\n");        		}else{        			log("開放自動注冊:NO\n");        		}      	}    }   	fclose(fp);    return 0;}BOOL sasql_init( void ){  readConfig("acserv.cf");  if(USEMSSQL==0)return TRUE;	char buf[257];	char ODBC[257];	short buflen;//	printf ("Initialize the environment structure.\n");	SQLAllocEnv (&henv);	//	printf ("Initialize the connection structure.\n");	SQLAllocConnect (henv,&hdbc);		printf("連接ODBC驅動器...");	sprintf(ODBC,"DSN=%s;UID=sa;PWD=123456;",config.SQL_DSN,config.SQL_USER,config.SQL_PASSWORD);	rc = SQLDriverConnect(hdbc,0,ODBC,SQL_NTS,(UCHAR*) buf,sizeof (buf),&buflen,SQL_DRIVER_COMPLETE);	check_return (rc,henv,hdbc,hstmt);	printf ("成功\n");	SQLAllocStmt (hdbc,&hstmt);	SQLBindCol(hstmt, 1, SQL_C_CHAR,&sid,16, &err);	SQLBindCol(hstmt, 2, SQL_C_CHAR,&sps,16, &err);}void sasql_close( void ){	if(USEMSSQL==0)return;//	printf ("Free the statement handle.\n");	SQLFreeStmt (hstmt,SQL_DROP);	//	printf ("Disconnect from the data source.\n");	SQLDisconnect (hdbc);	//	printf ("Free the connection structure.\n");	SQLFreeConnect (hdbc);	//	printf ("Free the environment structure.\n");	SQLFreeEnv (henv);}int sasql_query(char *id, char *ps){	if(USEMSSQL==0)return TRUE;	SQLCHAR sqlstr[128];	SQLCHAR szPass[64]={0};	SQLINTEGER cbPass;	SQLCancel(hstmt);	sprintf(sqlstr,"select * from %s where ID='%s'",config.SQL_INFOTABLE,id);	rc = SQLExecDirect( hstmt, sqlstr, SQL_NTS);	check_return (rc,henv,hdbc,hstmt);	if (rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO) 	{  	while( SQL_SUCCESS == SQLFetch(hstmt) ){  		if(SQLGetData(hstmt, 2, SQL_C_CHAR, szPass, 50, &cbPass) == SQL_SUCCESS)  			if(strcmp(szPass,ps)==0){					return 1;				}else{					printf("賬號%s密碼錯誤!\n",id);					return 2;				}		}		printf("賬號%s未注冊!\n",id);		return 3;	}	return 0;}BOOL sasql_register(char *id, char *ps){	if(AUTOREG){		SQLCHAR sqlstr[128];		SQLCancel(hstmt);		sprintf(sqlstr,"select * from %s where ID='%s'",config.SQL_INFOTABLE,id);		rc = SQLExecDirect( hstmt, sqlstr, SQL_NTS);		check_return (rc,henv,hdbc,hstmt);		if (rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO) 		{			while( SQL_SUCCESS == SQLFetch(hstmt) )				return FALSE;			SQLCancel(hstmt);			sprintf(sqlstr,"INSERT INTO %s (ID,PassWord,RegTime,Path) VALUES ('%s','%s',NOW(),'char/0x%x')",config.SQL_INFOTABLE, id, ps, getHash(id) & 0xff);			rc = SQLExecDirect( hstmt, sqlstr, SQL_NTS);			check_return (rc,henv,hdbc,hstmt);			if (rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO){				printf("新賬號%s注冊成功!\n",id);				return TRUE;			}		}	}	return FALSE;}void check_return (RETCODE rc,HENV henv,HDBC hdbc,HSTMT hstmt ){	UCHAR state_str [SQL_MAX_MESSAGE_LENGTH];	SDWORD native_error;	UCHAR error_msg [SQL_MAX_MESSAGE_LENGTH];	SWORD error_msg_avail = SQL_MAX_MESSAGE_LENGTH - 1;	SWORD error_msg_len;	RETCODE local_rc;		if (rc != SQL_ERROR && rc != SQL_SUCCESS_WITH_INFO )	{	return;	}		local_rc = SQLError(henv,hdbc,hstmt,state_str,&native_error,error_msg,error_msg_avail,&error_msg_len);	if (local_rc != SQL_SUCCESS && rc !=SQL_SUCCESS_WITH_INFO)	{		fprintf(stderr,"Uninterpretable error; exiting \n");		exit (EXIT_FAILURE);	}		if (rc == SQL_SUCCESS_WITH_INFO)	{		fprintf(stderr,"Fatal Error %s: %s\n", state_str,error_msg);		return;	}			fprintf(stderr,"Fatal Error %s: %s\n",state_str,error_msg); 		exit (EXIT_FAILURE);}BOOL sasql_craete_lock( void ){	char sqlstr[128];	SQLCancel(hstmt);	sprintf(sqlstr,"create table %s (Name varchar(16),PRIMARY KEY (Name));",config.SQL_LOCK);	rc = SQLExecDirect( hstmt, sqlstr, SQL_NTS);	check_return (rc,henv,hdbc,hstmt);	if (rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO) 	{		printf("鎖定用戶表建立成功!\n");  	return TRUE;	}	printf("鎖定用戶表建立失敗!\n");	return FALSE;}BOOL sasql_craete_userinfo( void ){	char sqlstr[255];	SQLCancel(hstmt);	sprintf(sqlstr,"CREATE TABLE %s ("									"ID varchar(16) NOT NULL,"									"PassWord varchar(16) NOT NULL,"									"IP varchar(16),"									"RegTime datetime,"									"LoginTime datetime,"									"OnlineName varchar(32),"									"Online int,"									"Path varchar(10),"									"PRIMARY KEY (ID));",config.SQL_INFOTABLE);	rc = SQLExecDirect( hstmt, sqlstr, SQL_NTS);	check_return (rc,henv,hdbc,hstmt);	if (rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO) 	{		printf("用戶信息表建立成功!\n");  	return TRUE;	}	printf("用戶信息表建立失敗!\n");	return FALSE;}BOOL sasql_chehk_lock( char *idip ){	char sqlstr[128];	SQLCancel(hstmt);	sprintf(sqlstr,"select * from %s where Name='%s'", config.SQL_LOCK, idip);	rc = SQLExecDirect( hstmt, sqlstr, SQL_NTS);	check_return (rc,henv,hdbc,hstmt);	if (rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO) 	{		while( SQL_SUCCESS == SQLFetch(hstmt) )			return TRUE;	}	return FALSE;}BOOL sasql_add_lock( char *idip ){	char sqlstr[128];	SQLCancel(hstmt);		sprintf(sqlstr,"INSERT INTO %s (Name) VALUES ('%s')", config.SQL_LOCK, idip);	rc = SQLExecDirect( hstmt, sqlstr, SQL_NTS);	check_return (rc,henv,hdbc,hstmt);	if (rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO) 	{		return TRUE;	}	return FALSE;}BOOL sasql_del_lock( char *idip ){	char sqlstr[128];	SQLCancel(hstmt);	sprintf(sqlstr,"delete from config.SQL_LOCK where Name='%s'", config.SQL_LOCK, idip);	rc = SQLExecDirect( hstmt, sqlstr, SQL_NTS);	check_return (rc,henv,hdbc,hstmt);	if (rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO) 	{		return TRUE;	}	return FALSE;}#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人综合在线观看| 色老汉一区二区三区| av电影天堂一区二区在线| 欧美优质美女网站| 久久久综合视频| 亚洲高清免费视频| k8久久久一区二区三区| 日韩欧美一区中文| 悠悠色在线精品| 成人av电影免费在线播放| 日韩欧美一区二区免费| 亚洲午夜久久久久久久久电影网 | 日本精品免费观看高清观看| 日韩精品一区二区在线| 午夜精品久久久久久久久| 波波电影院一区二区三区| 久久影院午夜论| 久久超碰97人人做人人爱| 欧美日韩一区二区三区在线看| 18欧美亚洲精品| 成a人片亚洲日本久久| 精品国产91乱码一区二区三区| 亚洲国产欧美在线| 91香蕉视频污在线| 亚洲欧洲精品一区二区精品久久久| 激情综合网av| 精品国产一二三区| 国产在线精品免费| 欧美精品一区二区三区高清aⅴ | 一区二区三区日韩欧美| www.在线成人| 国产女人aaa级久久久级| 激情另类小说区图片区视频区| 欧美一区二区高清| 日韩高清在线电影| 91精品国产一区二区三区蜜臀| 奇米影视在线99精品| 日韩视频在线永久播放| 久久精品国产在热久久| 精品剧情在线观看| 国产精品一区二区在线观看不卡| 久久精品视频在线看| 国产风韵犹存在线视精品| 国产欧美精品一区二区色综合 | 天堂va蜜桃一区二区三区漫画版| 欧美三级午夜理伦三级中视频| 亚洲国产精品一区二区www| 欧美群妇大交群中文字幕| 午夜精品一区在线观看| 777色狠狠一区二区三区| 人人爽香蕉精品| 久久精品一区二区三区四区| 91丨九色丨黑人外教| 亚洲综合小说图片| 欧美精品久久99久久在免费线| 久久国产精品72免费观看| 久久网这里都是精品| 91一区二区三区在线观看| 一区二区三区精品视频| 日韩欧美国产小视频| 成人激情动漫在线观看| 亚洲精品视频观看| 91精品国产综合久久久久久久| 国产真实乱子伦精品视频| 国产精品欧美久久久久无广告 | 欧美三级资源在线| 美女被吸乳得到大胸91| 国产欧美精品一区aⅴ影院 | 色噜噜夜夜夜综合网| 日本美女一区二区三区视频| 欧美国产日产图区| 欧美日韩一区小说| 成人av中文字幕| 久久国产欧美日韩精品| 一区二区三区在线播放| 久久久综合视频| 91.com在线观看| 91丝袜美女网| 国产乱理伦片在线观看夜一区| 一二三区精品视频| 国产精品美女久久久久久久网站| 91精品国产综合久久久蜜臀粉嫩| www.久久精品| 国产乱码精品一区二区三区忘忧草| 亚洲高清不卡在线观看| 国产精品毛片a∨一区二区三区| 91精品在线一区二区| av成人免费在线观看| 黑人巨大精品欧美一区| 香蕉加勒比综合久久| 亚洲日本青草视频在线怡红院| 精品福利一二区| 日韩欧美三级在线| 91精品国产综合久久香蕉的特点| 91福利资源站| 99这里只有精品| 懂色av一区二区在线播放| 久久激五月天综合精品| 日韩电影免费在线观看网站| 亚洲美女偷拍久久| 最新国产成人在线观看| 国产精品色呦呦| 国产精品视频第一区| 国产亚洲欧美一区在线观看| 日韩午夜电影av| 欧美日韩一区中文字幕| 欧美日韩dvd在线观看| 欧美日韩午夜精品| 欧美亚洲一区二区三区四区| 91免费视频观看| av一区二区三区四区| 成人精品电影在线观看| 成人免费看黄yyy456| eeuss鲁片一区二区三区在线观看| 国产剧情一区二区三区| 国产一区视频在线看| 国产精品一区不卡| 成人禁用看黄a在线| 丁香婷婷综合色啪| caoporen国产精品视频| 国产ts人妖一区二区| 成人综合婷婷国产精品久久蜜臀 | 国产拍欧美日韩视频二区| 久久久久久久综合狠狠综合| 久久久久青草大香线综合精品| 久久久亚洲精华液精华液精华液 | 午夜精品久久久久久久99水蜜桃 | 国产欧美一二三区| 国产精品久久久久久久浪潮网站| 国产精品丝袜一区| 一区二区不卡在线播放| 午夜日韩在线电影| 国内精品免费**视频| 大白屁股一区二区视频| 91国在线观看| 8x福利精品第一导航| 久久精品夜夜夜夜久久| 亚洲色图视频网| 日日夜夜一区二区| 国产精品综合二区| 色综合天天性综合| 欧美日韩国产综合一区二区 | 精品国产一二三区| 国产精品久久久久影院老司| 亚洲综合丝袜美腿| 蜜桃视频一区二区三区 | 国产精品一区一区| 99久久99久久综合| 91精品国产入口| 国产精品剧情在线亚洲| 日韩激情av在线| 波多野结衣一区二区三区| 欧美色综合久久| 26uuu色噜噜精品一区| 亚洲女爱视频在线| 国内精品免费**视频| 国产九色sp调教91| 久久精品av麻豆的观看方式| 亚洲精品成人在线| 亚洲自拍另类综合| 国产在线视频一区二区三区| av电影在线观看完整版一区二区| 欧美福利一区二区| 久久久综合精品| 欧美96一区二区免费视频| 成人激情av网| 久久久精品综合| 免费的成人av| 欧美中文字幕一区二区三区| 国产日本欧洲亚洲| 久久精品国产亚洲高清剧情介绍| 91一区二区三区在线观看| 久久日一线二线三线suv| 亚洲成av人综合在线观看| k8久久久一区二区三区| 久久免费视频一区| 另类的小说在线视频另类成人小视频在线| 波多野结衣视频一区| 国产亚洲欧美色| 青青青伊人色综合久久| 在线观看亚洲成人| 国产精品久久久久久久久快鸭| 狠狠色狠狠色综合系列| 51久久夜色精品国产麻豆| 亚洲成人午夜影院| 一本久久综合亚洲鲁鲁五月天 | 色综合久久中文综合久久97| 国产视频一区二区三区在线观看| 日av在线不卡| 欧美一区二区三区系列电影| 亚洲国产日韩在线一区模特| 91在线播放网址| 亚洲欧美日韩成人高清在线一区| 国产成人99久久亚洲综合精品| www久久久久| 国产成人精品aa毛片| 久久精品人人做人人爽97| 国产suv精品一区二区883| 久久久久久久久久电影| 国产一区二区不卡在线|