广告广告
  加入我的最爱 设为首页 风格修改
首页 首尾
 手机版   订阅   地图  繁体 
您是第 2276 个阅读者
 
发表文章 发表投票 回覆文章
  可列印版   加为IE收藏   收藏主题   上一主题 | 下一主题   
z2352671213
个人头像
个人文章 个人相簿 个人日记 个人地图
特殊贡献奖 社区建设奖
小人物
级别: 小人物 该用户目前不上站
推文 x10 鲜花 x47
分享: 转寄此文章 Facebook Plurk Twitter 复制连结到剪贴簿 转换为繁体 转换为简体 载入图片
推文 x0
[1.6][模组] 大神快来帮我看看这个源码为什么错了!!感激不尽!!
复制程式
#include <amxmodx>
#include <amxmisc>
#include <fakemeta>
#include <sqlx>
#include <zombieplague>


#define PLUGIN    "SIGN IN SYSTEM"
#define VERSION    "1.0"
#define AUTHOR    "NAG"
#define LOADING    "^n^t%s v%s, Copyright (C) 2014 by %s^n"

new Handle:g_SqlTuple;
new g_Error[512];

new g_SetAllow[33];

new g_host[33];
new g_user[33];
new g_pass[33];
new g_dbname[33];
new g_tabname[33];
new g_retryonce[33];
new Handle:g_Sql = Empty_Handle
public plugin_init()
{
    register_plugin(PLUGIN, VERSION, AUTHOR);
    server_print(LOADING,PLUGIN,VERSION,AUTHOR);
    register_forward(FM_ClientUserInfoChanged, "fwdClientUserInfoChanged");
    
    register_cvar("amx_sql_host", "127.0.0.1");
    register_cvar("amx_sql_user", "");
    register_cvar("amx_sql_pass", "");
    register_cvar("amx_sql_db", "");
    register_cvar("amx_sql_table", "");

    register_clcmd("say /qiandao","sign_say",ADMIN_ALL,"读取玩家说的话")

    new configsDir[64];
    get_configsdir(configsDir, 63);
    server_cmd("exec %s/sql.cfg", configsDir);
    server_exec();
}

public plugin_cfg()
{
    get_cvar_string("amx_sql_host",g_host,32);
    get_cvar_string("amx_sql_user",g_user,32);
    get_cvar_string("amx_sql_pass",g_pass,32);
    get_cvar_string("amx_sql_db",g_dbname,32);
    get_cvar_string("amx_sql_table",g_tabname,32);
    MySql_Init();
}

public MySql_Init()
{
    g_SqlTuple = SQL_MakeDbTuple(g_host,g_user,g_pass,g_dbname);
    new ErrorCode,Handle:SqlConnection = SQL_Connect(g_SqlTuple,ErrorCode,g_Error,charsmax(g_Error));
    if(SqlConnection == Empty_Handle)
        set_fail_state(g_Error);
    
    new Handle:Queries;
    Queries = SQL_PrepareQuery(SqlConnection,"CREATE TABLE IF NOT EXISTS %s (date int(30),name varchar(64), state varchar(64))", g_tabname);
    if(!SQL_Execute(Queries))
    {
        SQL_QueryError(Queries,g_Error,charsmax(g_Error));
        set_fail_state(g_Error);
    }
    SQL_FreeHandle(Queries);
    SQL_FreeHandle(SqlConnection);
}


public plugin_end()
    SQL_FreeHandle(g_SqlTuple);


public sign_say(id){
    new ErrorCode,Handle:SqlConnectionc = SQL_Connect(g_SqlTuple,ErrorCode,g_Error,charsmax(g_Error));
    new username[64]
    new timed[9]
    new xyb
    xyb = random_num(10,100)
    get_time("%m%d%Y",timed,8) 
    get_user_name(id,username,63)
    if(is_user_connected(id))
    {


    new chaxun;
    chaxun = SQL_QueryAndIgnore(SqlConnectionc,"SELECT * FROM  %s WHERE date = %d AND name = %s", g_tabname, str_to_num(timed) ,username[id]);


    if(chaxun == 0){
        SQL_QueryAndIgnore(SqlConnectionc,"INSERT INTO %s SET date = %d , name = %s, state = 'on'", g_tabname, str_to_num(timed) ,username[id])

        client_print(0,print_chat,"【元朝天尊每日签到】玩家[%s]签到成功,获得%d天尊币随机奖励!",username[id],xyb)
        zp_set_user_ammo_packs(id,zp_get_user_ammo_packs(id) + xyb)
    }
    else
    {
        client_print(id,print_chat,"【元朝天尊每日签到】您今日已经签过到了,赶明儿再来签到吧!")

    }


    SQL_FreeHandle(chaxun) ;

}

}

我写的这个插件,不过在游戏中一说/qiandao,马上服务器就崩溃了,求破。。!


[ 此文章被z2352671213在2014-02-09 16:10重新编辑 ]



献花 x0 回到顶端 [楼 主] From:未知地址 | Posted:2014-02-09 16:00 |
Nailaz 手机
个人头像
个人文章 个人相簿 个人日记 个人地图
特殊贡献奖 社区建设奖 创作大师奖
小有名气
级别: 小有名气 该用户目前不上站
推文 x77 鲜花 x254
分享: 转寄此文章 Facebook Plurk Twitter 复制连结到剪贴簿 转换为繁体 转换为简体 载入图片

读取玩家说的话
改成英文试看看..


web front-end and software engineer.
献花 x0 回到顶端 [1 楼] From:台湾中华电信股份有限公司 | Posted:2014-02-09 18:38 |
a7811311622 手机
个人头像
个人文章 个人相簿 个人日记 个人地图
特殊贡献奖 优秀管理员勋章 社区建设奖
头衔:我…在工作了…我…在工作了…
版主
级别: 版主 该用户目前不上站
版区: CS提问区
推文 x771 鲜花 x2152
分享: 转寄此文章 Facebook Plurk Twitter 复制连结到剪贴簿 转换为繁体 转换为简体 载入图片

下面是引用 z2352671213 于 2014-02-09 16:00 发表的 大神快来帮我看看这个源码为什么错了!!感激不尽!!: 到引言文
.......
我只写过VB的SQL…所以不是很清楚AMXX的SQL…
不过…我看了<sqlx.inc>里的 SQL_QueryAndIgnore …
说明不是说:
复制程式
/**
 * Use this for executing a query and not caring about the error.
 * Returns -1 on error, >=0 on success (with number of affected rows)
 */
可是你的逻辑是 if(chaxun == 0) …
这样不会有问题吗…?


尚无签名,欢迎 [新增个性化签名]
献花 x0 回到顶端 [2 楼] From:台湾中华电信股份有限公司 | Posted:2014-02-09 19:40 |
z2352671213
个人头像
个人文章 个人相簿 个人日记 个人地图
特殊贡献奖 社区建设奖
小人物
级别: 小人物 该用户目前不上站
推文 x10 鲜花 x47
分享: 转寄此文章 Facebook Plurk Twitter 复制连结到剪贴簿 转换为繁体 转换为简体 载入图片

下面是引用 a7811311622 于 2014-02-09 19:40 发表的 : 到引言文

我只写过VB的SQL…所以不是很清楚AMXX的SQL…
不过…我看了<sqlx.inc>里的 SQL_QueryAndIgnore …
说明不是说:
复制程式
/**
 * Use this for executing a query and not caring about the error.
 * Returns -1 on error, >=0 on success (with number of affected rows)
 */
可是你的逻辑是 if(chaxun == 0) …
这样不会有问题吗…?

谢了。确实是-1

再问一下,为什么用get_user_name获取的玩家ID,保存到SQL里都变成乱码了?而且玩家的ID有时候获取出来是空的。怎么回事


献花 x0 回到顶端 [3 楼] From:美国 | Posted:2014-02-09 20:08 |
a7811311622 手机
个人头像
个人文章 个人相簿 个人日记 个人地图
特殊贡献奖 优秀管理员勋章 社区建设奖
头衔:我…在工作了…我…在工作了…
版主
级别: 版主 该用户目前不上站
版区: CS提问区
推文 x771 鲜花 x2152
分享: 转寄此文章 Facebook Plurk Twitter 复制连结到剪贴簿 转换为繁体 转换为简体 载入图片

下面是引用 z2352671213 于 2014-02-09 20:08 发表的 : 到引言文


谢了。确实是-1

再问一下,为什么用get_user_name获取的玩家ID,保存到SQL里都变成乱码了?而且玩家的ID有时候获取出来是空的。怎么回事
有试过SMA存成UTF-8吗?
如果你的玩家名字是中文的…可能会出问题吧…
不知道AMXX能否正确存取中文…


尚无签名,欢迎 [新增个性化签名]
献花 x0 回到顶端 [4 楼] From:台湾中华电信股份有限公司 | Posted:2014-02-09 21:27 |
85607417
数位造型
个人文章 个人相簿 个人日记 个人地图
初露锋芒
级别: 初露锋芒 该用户目前不上站
推文 x5 鲜花 x15
分享: 转寄此文章 Facebook Plurk Twitter 复制连结到剪贴簿 转换为繁体 转换为简体 载入图片

图 1.

图 2.

图 3.



SQL里面乱码,但只要PHP能正常显示就可以
如果是空的,应该是保存方式有问题,编码统一用utf8
http://imgur.com/t6Lev...u,jSDGlO6


献花 x0 回到顶端 [5 楼] From:台湾中华电信股份有限公司 | Posted:2014-02-20 01:45 |

首页  发表文章 发表投票 回覆文章
Powered by PHPWind v1.3.6
Copyright © 2003-04 PHPWind
Processed in 0.032306 second(s),query:16 Gzip disabled
本站由 瀛睿律师事务所 担任常年法律顾问 | 免责声明 | 本网站已依台湾网站内容分级规定处理 | 连络我们 | 访客留言