新秀网络验证内部常用函数
新秀网络验证内部常用函数
1、此页面函数可用于内置扩展、接口开发、插件开发方法中调取;
2、此页面函数均为验证框架内部使用函数,经过自定义封装;3、用于二次开发时,请大家认真阅读使用说明,调试完成后,再用于正式环境。
xx_client::核心类函数
/**
* 获取接口api插件标识符
* @return mixed
*/
xx_client::get_plugin_ver();
/*生成唯一标志
*标准的UUID格式为:xxxxxxxx-xxxx-xxxx-xxxxxx-xxxxxxxxxx(8-4-4-4-12)
*/
xx_client::sgin_uuid($str);
/**
* 获取当前登录uid信息
* @param null $do // 默认0返回uid、1获取用户名、2获取用户组id、3获取管理组id
* @return mixed
*/
xx_client::uid_by_token($do = null);
/**
* HOOK反射钩子
* @param $name//扩展方法名
* @param array $arr// 传入钩子数据 数组型
* @return bool|mixed // 返回数据
* 实例:xx_client::class_hook('hook_'.$this->action,array($uid,$_GET));
*/
xx_client::class_hook($name,$arr=array());
/**
* 网络验证内置结束退出方法,接口访问完成后退出保存日志
* @param $code //状态码 200 成功400 失败
* @param string $result //错误提示码 OK代表成功 失败填写提示语
* @param string $data //成功后返回数组数据,json、xml两种形式
*/
xx_client::json_output($code,$result='',$data='');
/**
* 接收GET、POST传入参数,并转义,适用于字符串
* @param $params //参数名 & 开头的参数
* @param bool $iscore //如果填:true 则GET、POST参数中必须包含此参数,即接口文档所说必填参数,如果缺失将报错;
* @return bool|mixed|string //返回传入对应参数值
*/
xx_client::safe_check($params, $iscore = false);
/**
* 接收GET、POST传入参数,并转义,适用数字
* @param $params //参数名 & 开头的参数
* @param bool $iscore //如果填:true 则GET、POST参数中必须包含此参数,即接口文档所说必填参数,如果缺失将报错;
* @return bool|mixed|string //返回传入对应参数值
*/
xx_client::safe_check_uid($params, $iscore = false);
/**
* 接口退出时自定义返回字段
* @param $fields // 自定义返回字段数组
* @param $output // 接口退出时返回的数据
* @return mixed|string
* 例子:xx_client::hook_exit_fields(array('uid','username'),$output);
*/
xx_client::hook_exit_fields(array('uid','username'),$output);
//获取客户端真实IP
xx_client::get_client_ip();
xx_output::返回类函数
/**
* 网络验证内置结束退出方法,接口访问完成后退出保存日志
* @param $code //状态码 200 成功400 失败
* @param string $result //错误提示码 OK代表成功 失败填写提示语
* @param string $data //成功后返回数组数据,json、xml两种形式
*/
xx_output::json_output($code,$result='',$data='');
xx_cache::缓存类函数
/**
* 获取data文件列表内缓存文件列表
* @param $pathfile //缓存目录名称 例子:'mulu/mulu1' /斜杠两侧都是文件名
* @return array|false //返回对应文件下所有缓存变量名
*/
xx_cache::cache_list($pathfile);
/**
* 获取指定缓存变量值
* @param $pathfile //缓存目录及文件名称 例子:'mulu/mulu1/wenjian' /斜杠前面都是目录,最后面是文件名
* @param array $keys //获取缓存值数组,支持N级读取,array('key','key1',...) ,
* 如果为空,返回全部数组或文本
* @param bool $crypt // 是否是加密数据,默认为假
* @return mixed
*/
xx_cache::get_cache($pathfile,$keys = array(),$crypt=false);
/**
* 设置指定缓存变量值
* @param $pathfile //缓存目录及文件名称 例子:'mulu/mulu1/wenjian' /斜杠前面都是目录,最后面是文件名
* @param array $keys //设置缓存值数组,支持N级设置,array('key'=>array('keys',''keys1'),'key1'=>'demo',...) ,
* 如果不是数组设置为指定文本
* @param bool $crypt // 是否是加密数据,默认为假
* @return mixed
*/
xx_cache::set_cache($pathfile,$keys = array(),$crypt=false);
/**
* 合并数组缓存文件
* @param $pathfile //缓存目录及文件名称 例子:'mulu/mulu1/wenjian' /斜杠前面都是目录,最后面是文件名
* @param array $keys //新增缓存文件,数组型,如果两个或更多个数组元素有相同的键名,则最后的元素会覆盖其他元素。
* 如果是文本加入数组,或者数组加入文本,文本加入文本都不会覆盖
* @param bool $crypt // 是否是加密数据,默认为假
* @return mixed
*/
xx_cache::add_cache($pathfile,$keys = array(),$crypt=false);
/**
* 出栈数组最后一个元素
* @param $pathfile//缓存目录及文件名称 例子:'mulu/mulu1/wenjian' /斜杠前面都是目录,最后面是文件名
* @param bool $crypt // 是否是加密数据,默认为假
* @return false|mixed|null
*/
xx_cache::pop_cache($pathfile,$crypt=false);
/**
* 查询所有一维数组键名与键值对应键名
* @param $pathfile //缓存目录及文件名称 例子:'mulu/mulu1/wenjian' /斜杠前面都是目录,最后面是文件名
* @param null $type //输入键值反查对应的键名,如果为空,则返回所有键名
* @param bool $crypt // 是否是加密数据,默认为假
* @return int[]|string[]
*/
xx_cache::keys_cache($pathfile,$type = null,$crypt=false);
/**
*返回随机键名,即抽奖程序
* @param $pathfile //缓存目录及文件名称 例子:'mulu/mulu1/wenjian' /斜杠前面都是目录,最后面是文件名
* @param 1 $int //输入返回随机键值的数量,默认为1
* @param bool $crypt // 是否是加密数据,默认为假
* @return int[]|string[]
*/
xx_cache::rand_cache($pathfile,$int = 1,$crypt=false);
/**
* 输入对应值,搜索对应键名
* @param $pathfile//缓存目录及文件名称 例子:'mulu/mulu1/wenjian' /斜杠前面都是目录,最后面是文件名
* @param $type//输入键值反查对应的键名,不能为空,则返回所有键名
* @param false $strict //默认为假,如果设置为 true,则在数组中检查给定值的类型,数字 5 和字符串 5 是不同的
* @param bool $crypt // 是否是加密数据,默认为假
* @return false|int|string
*/
xx_cache::search_cache($pathfile,$type,$strict = false,$crypt=false);
/**
* 删除指定变量值及变量缓存文件
* @param $pathfile //缓存目录及文件名称 例子:'mulu/mulu1/wenjian' /斜杠前面都是目录,最后面是文件名
* @param null $keys //缓存数组keys目前只支持五级数组
* @param bool $crypt // 是否是加密数据,默认为假
* @return bool|int|void
*/
xx_cache::del_cache($pathfile,$keys = array(),$crypt=false);
xx_mysql::数据库类函数
/**
* 设置临时数据库配置文件
* @param $host //服务器地址
* @param $user //数据库用户名
* @param $name //数据库名
* @param $pw //数据库密码
* @return array //返回原数据库配置文件,配合退出数据库方法适用
*/
xx_mysql::set_db_config($host,$user,$name,$pw);
/**
* 返回数据库
* @param array $arr //提交切换数据库返回配置文件
* @return mixed
*/
xx_mysql::exit_db($arr= array());
/**
* 模糊搜索数据库返回数据
* @param $table//搜索表名称
* @param $rule //搜索规则 接口规则“或”和“且”用“|”分开,多关键字用“-”分开
* 例:标-的|标-题(包含标或的,且必须包含标和题)
* 例:标题 (搜索包含标题的帖子)
* 例:标题-发现(搜索包含标题或发现的帖子)
* @param $ruletab //搜索字段
* @param string $field //返回字段array
* @param string $order //排序字段
* @param string $start //开始数据
* @param string $limit //结束数据
* @param string $sort //排序规则
* @return array
*/
xx_mysql::fetch_all_search ($table,$rule,$ruletab,$field = "id",$order = "id",$start = "",$limit = "",$sort = '');
/**
* 搜索返回数据内容
* @param $table//搜索表名称
* @param $ruletab //搜索字段规则 例如 id=1
* @param string $field //返回字段array
* @param string $order //排序字段
* @param string $start //开始数据
* @param string $limit //结束数据
* @param string $sort //排序规则
* @return array
* 实例如下:
* return xx_mysql::fetch_all("common_usergroup_field","1=1",array("groupid","readaccess","allowpost"),"groupid");
*/
xx_mysql::fetch_all ($table,$ruletab,$field,$order = "id",$start = "",$limit = "",$sort = '');
/**
* 搜索返回数据整条内容
* @param $table//搜索表名称
* @param $ruletab //搜索字段规则 例如 id=1
* @param string $field //返回字段array
* @return array
* 实例如下:
* return xx_mysql::fetch_first('common_credit_log','uid=3',array());
*/
xx_mysql::fetch_first ($table,$ruletab,$field =false);
/* 数据表更新操作
* 方法名:DB::update()
* 插入的值如果是变量用array(),DB::update('borle_do',array('countMoney' => $countMoney),array('doId'=> $doId),true);}
* $table:(更新数据的表)
* $data:更新的数据,字段对应的
* $condition:更新的条件,必须包含主键id
* $unbuffrerd:是否使用无缓存查询
* $low_priority:是否采用无损更新表
*/
xx_mysql::update_all($table,$data,$condition);
/*
* 数据表删除操作
方法名:DB::delete()
参数解释:
$table:删除数据的表
$condition:删除条件 支持uid=1文本,也支持数组,数组传入时都是并为真执行
$limit:删除满足条件的目数
$unbuffered:是否使用无缓存查询
*/
xx_mysql::delete($table,$condition,$limit=1);
/*
* 数据库插入数据
* $table:插入数据的表 $data:插入的数据,字段对应值
* $dataarray 插入数据数组
* $return_insert_id:是否返回插入数据的ID
* $replace:是否使用replace into如果为真: 当存在数据执行修改,不存在执行写入,返回uid,
* 注意数组重必须包含主键uid array('uid' => '1','dname' => 'ppc', )
* $slient:操作失败是否不提示
*/
xx_mysql::insert($table,$dataarray='',$replace = false);
xx_curl::访问类函数
/**
* get访问url网址接口
* @param $url //地址
* @return bool|string
*/
xx_curl::get_url($url);
/**
* post访问url地址,并提交数据
* @param $url //地址
* @param $post_data //数组型
* @return bool|string
*/
xx_curl::post_url($url, $post_data);
/**
* post访问url地址,并提交json数据
* @param $url
* @param $data_string //json
* @return false|string
*/
xx_curl::post_url_json($url, $post_json) ;
/**
* 自动跳转页面登录状态
* @param $uid // 设置用户uid
* @param $url //打开指定网址
* @param $jump //是否跳转
*/
xx_curl::send_url($uid,$url,$jump);
/**
* JS提示跳转
* @param$tip弹窗口提示信息(为空没有提示)
* @param$type 设置类型 close = 关闭 ,back=返回 ,refresh=提示重载,jump提示并跳转url
* @param$url跳转url
*/
xx_curl::alert($tip, $type, $url) ;
xx_cookie::cookie类函数
/**
* 设置cookie
* @param $var - 变量名
* @param $value - 变量值
* @param $life - 生命期
*/
xx_cookie::set_cookie($var, $value = '', $life = 0);
/**
* 获取cookie
* @param $key - cookie名称,不需要带前缀
*/
xx_cookie::get_cookie($key);
/**
* 删除cookie
* @param $var - 变量名
*/
xx_cookie::del_cookie($var);
/**
* 删除所有cookie
*/
xx_cookie::del_cookie_all();
xx_dz_members::用户类函数
/**
* 检测积分下限是否够积分扣除
* @param $action // array(2=>100) 其中2为extcredits积分编号,100为需要扣除的积分数量
* @param $uid //用户uid
* @return bool //如果积分大于或等于所要扣除积分,则返回真,如果不够扣除则返回假
*/
xx_dz_members::check_credits_limit($action,$uid);
/**
* 通过uid获取uc用户数据
* @param $uid //用户uid
* @param $ziduan //获取用户字段
uid mediumint(8) unsigned NO 是 用户ID
username char(15) NO 用户名
password char(32) NO 密码
email char(32) NO 用户Email
myid char(30) NO 漫游id
myidkey char(16) NO 漫游id
regip char(15) NO 注册IP
regdate int(10) unsigned 0 NO 注册时间
lastloginip int(10) 0 NO 上次登陆的IP(程序转换成数值类型)
lastlogintime int(10) unsigned 0 NO 上次登录的时间
salt char(6) NO 密码干扰串,用来和密码进行配合验证,防止被暴力破解
secques char(8) NO 用户的安全提问
*/
xx_dz_members::uc_by_uid($uid,$ziduan);
/**
* 返回用户登录名(uid、username、email、sgin、qq、weixin、phone)
* @param $name //输入uid、username、email、sgin、qq、weixin、phone
* @param string $type //定义输出内容 uid、username、email、sgin、qq、weixin、phone 为空返回全部
* @param string $output //定义查询为空时,是否直接退出程序,默认假
* @return array|false|mixed //失败返回假
*/
xx_dz_members::get_by_uid($name,$type='',$output = false);
/**
* 返回启用积分信息
* @param $int //积分类型id 1-8
* @param string $type //返回类型字段 默认返回title
* @return mixed
*/
xx_dz_members::extcredits($int,$type);
/**
* 通过用户组id,返回用户组信息表
* @param $int //用户组id
* @param null $type // 如果是空返回对应用户组id所有字段,如果填写字段则返回对应字段信息
* @return mixed
*/
xx_dz_members::usergroup($int,$type);
/**
* 通过uid获取用户会员组groupid
* @param $uid
* @return mixed 返回用户组id
*/
xx_dz_members::usergroup_by_uid($uid);
/**
* 通过uid获取用户管理组adminid
* @param $uid
* @return mixed 返回管理组id
*/
xx_dz_members::adminid_by_uid($uid);
xx_email::邮件类函数
/**
*发送指定邮件,通用版
* @param $toemail // 对方邮箱地址
* @param $subject // 邮件标题
* @param $message // 邮件内容
* @param $array // 邮件内容,关键字替换:array('要改变的字符'=>'要改变为的字符')
* @param $sitename //邮件标题,前面[站点名称]
* @return bool
*/
xx_email::send_email($toemail, $subject,$message,$array,$sitename='');
/**
* Discuz内置,论坛注册地址发送邀请
* @param $toemail // 对方邮箱地址
* @param string $sitename //邮件标题,前面[站点名称]
* @return bool//返回真或假
*/
xx_email::email_dz_register($toemail,$sitename='');
/**
* Discuz内置,取回密码邮件发送
* @param $toemail // 对方邮箱地址
* @param string $sitename //邮件标题,前面[站点名称]
* @return bool //返回真或假
*/
xx_email::email_dz_passwd($toemail,$sitename='');
111111111111111111
页:
[1]