qq配置文件
路径:application/config/isetting/qq_setting.php
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
/**
* @qq互联配置信息
* 默认开启get_user_info模块
* **/
$config['inc_info'] = array(
array (
'appid' => '101091040',
'appkey' => '7cb031049f2c900fea809424e614a968',
'callback' => '此为绑定的url/qqcallback.php'
),
array (
'get_user_info' => '1',
'add_topic' => '0',
'add_one_blog' => '0',
'add_album' => '0',
'upload_pic' => '0',
'list_album' => '0',
'add_share' => '0',
'check_page_fans' => '0',
'add_t' => '0',
'add_pic_t' => '0',
'del_t' => '0',
'get_repost_list' => '0',
'get_info' => '0',
'get_other_info' => '0',
'get_fanslist' => '0',
'get_idollist' => '0',
'add_idol' => '0',
'del_idol' => '0',
'get_tenpay_addr' => '0',
)
);
根目录下的,qqcallback.php
<?php
/*
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
//新浪微博登录回调入口文件,将路径转移到login/callback方法里,并将code值传过去
$code ='';
$state='';
$url = '';
$str ='';
$code = $_REQUEST['code'];
$state = $_REQUEST['state'];
$url = "/login/qqcallback";
//die('ssss');
$str = "<!doctype html>
<html>
<head>
<meta charset=\"UTF-8\">
<title>自动跳转</title>
</head>
<body>";
$str .="<form action=\"{$url}\" method=\"post\" id=\"form\" autocomplete='off'>";
$str .="<input type='hidden' name='code' value='{$code}'>";
$str .="<input type='hidden' name='state' value='{$state}'>";
$str .=" <!--<p><input type='submit' value='go'/></p> -->
</form>
</body>
</html>
<script type=\"text/javascript\">
document.getElementById('form').submit();
</script>";
echo $str;
login控制器下的qqcallback方法
public function qqcallback(){
header("content-type: text/html; charset=utf-8");
$this->load->library('tencent/oauth','oauth');
$this->load->model("user_reg_model","user_reg");
$code = $_REQUEST['code'];
$state = $_REQUEST['state'];
$CI = &get_instance();
$CI->config->load('isetting/qq_setting');
$setting = $CI->config->item('inc_info');
$appid = $setting[0]['appid'];
$arr =array();
$arr = $this->oauth->qq_callback($code,$state,$appid);
// echo "<pre>";print_r($arr);die();
$res = $this->third->select_third(array("qq_id"=>$arr['openid']));
if(!empty($res)){
$user_info = $this->user_reg->user_detect(array("id"=>$res['user_id']));
if($user_info['status']){
echo "<script>alert('您登陆的账号还未激活');location='/login/index';</script>";die();
}
$datas = $this->third->select_user_qqname($arr['openid']);
// echo "<pre>";print_r($datas);die();
$uname = $datas['username'];
$password = $datas['password'];
$this->load->model("login_model","login");
$this->login->validation($uname,$password);
echo "<script>alert('登录成功!');location='/user_center'</script>";die();
}else{
$this->session->set_userdata('qq_id',$arr['openid']);
echo "<script>if(!confirm('是否在平台注册过用户?')){location='/register/index'}else{location='/login'};</script>";
}
}
models下的模型
<?php
/**
* Description of third_login_model
*新浪接口授权及登录model
* @author
*/
class third_login_model extends CI_Model{
//put your code here
private $sina=array();
private $qq =array();
private $users ='';
private $third='';
public function __construct() {
parent::__construct();
// $this->l = DIRECTORY_SEPARATOR;
$this->load->database();
$this->load->library('session');
include_once APPPATH."/libraries"."/saetv2.ex.class.php";
$this->third = $this->db->dbprefix.'_third_login';
$this->users = $this->db->dbprefix.'_user_reg';
$this->config->load("sina_conf");
$this->sina= $this->config->item("sina_conf");
}
/**
* @uses : 新浪微博登录
* @param :
* @return : $sina_url----登录地址
*/
public function sina_login(){
$obj = new SaeTOAuthV2($this->sina['App_Key'],$this->sina['App_Secret']);
$sina_url = $obj->getAuthorizeURL( $this->sina['WB_CALLBACK_URL'] );
return $sina_url;
}
/**
* @uses : 登录后,通过返回的code值,获取token,实现授权完成,然后获取用户信息
* @param : $code
* @return : $user_message--用户信息
*/
public function sina_callback($code){
$obj = new SaeTOAuthV2($this->sina['App_Key'],$this->sina['App_Secret']);
if (isset($code)) {
$keys = array();
$keys['code'] = $code;
$keys['redirect_uri'] = $this->sina['WB_CALLBACK_URL'];
try {
$token = $obj->getAccessToken( 'code', $keys ) ;//完成授权
} catch (OAuthException $e) {
}
}
$c = new SaeTClientV2($this->sina['App_Key'], $this->sina['App_Secret'], $token['access_token']);
$ms =$c->home_timeline();
$uid_get = $c->get_uid();//获取u_id
$uid = $uid_get['uid'];
$user_message = $c->show_user_by_id($uid);//获取用户信息
return $user_message;
}
/**
* @uses : 查询第三方登录表
* @param : $where
* @return : 第三方登录用户记录结果集
*/
public function select_third($where) {
$result = false;
$this->db->select();
$this->db->from($this->third);
$this->db->where($where);
$query = $this->db->get();
if($query){
$result = $query->row_array();
}
return $result;
}
/**
* @uses : sina查询用户表和第三方登录表
* @param : $where
* @return : 第三方登录用户记录结果集
*/
public function select_user_name($where) {
$field ="user.id,user.password,user.username,utl.*";
$sql = "select {$field} from {$this->third} as utl "
." left join {$this->users} as user on user.id=utl.user_id"
. " where utl.sina_id={$where}";
$query = $this->db->query($sql);
$result = $query->row_array();
return $result;
}
/**
* @uses : qq查询用户表和第三方登录表
* @param : $where
* @return : 第三方登录用户记录结果集
*/
public function select_user_qqname($where) {
$field ="user.id,user.password,user.username,utl.*";
$sql = "select {$field} from {$this->third} as utl "
." left join {$this->users} as user on user.id=utl.user_id"
. " where utl.qq_id='{$where}'";
$query = $this->db->query($sql);
$result = $query->row_array();
return $result;
}
// public function insert_third($datas){
// if (!is_array($datas)) show_error ('wrong param');
// $res ='';
// $res = $this->db->insert($this->third, $datas);
// return $res;
// }
//
// public function up_third($datas) {
//
// }
public function binding_third($datas) {
if (!is_array($datas)) show_error ('wrong param');
if($datas['sina_id']==0 && $datas['qq_id']==0) return;
$resa ='';
$resb ='';
$resa = $this->select_third(array("user_id"=>$datas['user_id']));
$temp =array(
"user_id"=>$datas['user_id'],
"sina_id"=>$resa['sina_id']!=0 ? $resa['sina_id'] : $datas['sina_id'],
"qq_id" => $resa['qq_id']!=0 ? $resa['qq_id'] : $datas['qq_id'],
);
if($resa){
$resb = $this->db->update($this->third, $temp,array("user_id"=>$datas['user_id']));
}else{
$resb = $this->db->insert($this->third,$temp);
}
if($resb) {
$this->session->unset_userdata('sina_id');
$this->session->unset_userdata('qq_id');
}
return $resb;
}
}
libraries/tencent/oauth.php在下载附件中
新浪配置文件
application/config/sina_conf.php
<?php
$config["sina_conf"] = array( //测试机
"App_Key" => '1498005339',
"App_Secret" =>'f1c6277a38b39f764c76a1190750a6dc',
"WB_CALLBACK_URL" => 'http://.../callback.php'
);
根目录下的回调地址 callback.php
<?php
/*
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
//新浪微博登录回调入口文件,将路径转移到login/callback方法里,并将code值传过去
$code ='';
$url = '';
$str ='';
$code = $_REQUEST['code'];
$url = "/login/callback";
$str = "<!doctype html>
<html>
<head>
<meta charset=\"UTF-8\">
<title>自动跳转</title>
</head>
<body>";
$str .="<form action=\"{$url}\" method=\"post\" id=\"form\" autocomplete='off'>";
$str .="<input type='hidden' name='code' value='{$code}'>";
$str .="</form>
</body>
</html>
<script type=\"text/javascript\">
document.getElementById('form').submit();
</script>";
echo $str;
请求的方法
//流程原理:
// 1.通过code获得access_token通过授权,并获取用户的信息(包括用户u_id)
// 2.查询第三方登录表,如果存在用户id,查询用户表,如果邮箱已经激活,就直接登录,如果没有激活,提示用户去邮箱激活帐号
// 3.查询第三方登录表,如果不存在用户id,分2种情况,一:用户在平台已经有帐号了,这时需要把平台user_reg用户id绑定到第三方登录表,然后就让客户登录
// 二:如果用户在平台没有帐号,跳转至注册页面注册,注册的同时,信息写入uer_reg表,同时也把用户id写入第三方登录表进行绑定
public function callback(){
header("content-type: text/html; charset=utf-8");
$this->load->model("user_reg_model","user_reg");
$code = $_REQUEST['code'];//code值由入口文件callback.php传过来
$arr =array();
$arr = $this->third->sina_callback($code);//通过授权并获取用户信息(包括u_id)
$res = $this->third->select_third(array("sina_id"=>$arr['id']));
if(!empty($res)){
$user_info = $this->user_reg->user_detect(array("id"=>$res['user_id']));
if($user_info['status']){
echo "<script>alert('您登陆的账号还未激活');location='/login/index';</script>";die();
}
$datas = $this->third->select_user_name($arr['id']);
// echo "<pre>";print_r($datas);die();
$uname = $datas['username'];
$password = $datas['password'];
$this->load->model("login_model","login");
$this->login->validation($uname,$password);
echo "<script>alert('登录成功!');location='/user_center'</script>";die();
}else{
$this->session->set_userdata('sina_id',$arr['id']);
echo "<script>if(!confirm('是否在平台注册过用户?')){location='/register/index'}else{location='/login'};</script>";
}
}
路径:application/config/isetting/qq_setting.php
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
/**
* @qq互联配置信息
* 默认开启get_user_info模块
* **/
$config['inc_info'] = array(
array (
'appid' => '101091040',
'appkey' => '7cb031049f2c900fea809424e614a968',
'callback' => '此为绑定的url/qqcallback.php'
),
array (
'get_user_info' => '1',
'add_topic' => '0',
'add_one_blog' => '0',
'add_album' => '0',
'upload_pic' => '0',
'list_album' => '0',
'add_share' => '0',
'check_page_fans' => '0',
'add_t' => '0',
'add_pic_t' => '0',
'del_t' => '0',
'get_repost_list' => '0',
'get_info' => '0',
'get_other_info' => '0',
'get_fanslist' => '0',
'get_idollist' => '0',
'add_idol' => '0',
'del_idol' => '0',
'get_tenpay_addr' => '0',
)
);
根目录下的,qqcallback.php
<?php
/*
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
//新浪微博登录回调入口文件,将路径转移到login/callback方法里,并将code值传过去
$code ='';
$state='';
$url = '';
$str ='';
$code = $_REQUEST['code'];
$state = $_REQUEST['state'];
$url = "/login/qqcallback";
//die('ssss');
$str = "<!doctype html>
<html>
<head>
<meta charset=\"UTF-8\">
<title>自动跳转</title>
</head>
<body>";
$str .="<form action=\"{$url}\" method=\"post\" id=\"form\" autocomplete='off'>";
$str .="<input type='hidden' name='code' value='{$code}'>";
$str .="<input type='hidden' name='state' value='{$state}'>";
$str .=" <!--<p><input type='submit' value='go'/></p> -->
</form>
</body>
</html>
<script type=\"text/javascript\">
document.getElementById('form').submit();
</script>";
echo $str;
login控制器下的qqcallback方法
public function qqcallback(){
header("content-type: text/html; charset=utf-8");
$this->load->library('tencent/oauth','oauth');
$this->load->model("user_reg_model","user_reg");
$code = $_REQUEST['code'];
$state = $_REQUEST['state'];
$CI = &get_instance();
$CI->config->load('isetting/qq_setting');
$setting = $CI->config->item('inc_info');
$appid = $setting[0]['appid'];
$arr =array();
$arr = $this->oauth->qq_callback($code,$state,$appid);
// echo "<pre>";print_r($arr);die();
$res = $this->third->select_third(array("qq_id"=>$arr['openid']));
if(!empty($res)){
$user_info = $this->user_reg->user_detect(array("id"=>$res['user_id']));
if($user_info['status']){
echo "<script>alert('您登陆的账号还未激活');location='/login/index';</script>";die();
}
$datas = $this->third->select_user_qqname($arr['openid']);
// echo "<pre>";print_r($datas);die();
$uname = $datas['username'];
$password = $datas['password'];
$this->load->model("login_model","login");
$this->login->validation($uname,$password);
echo "<script>alert('登录成功!');location='/user_center'</script>";die();
}else{
$this->session->set_userdata('qq_id',$arr['openid']);
echo "<script>if(!confirm('是否在平台注册过用户?')){location='/register/index'}else{location='/login'};</script>";
}
}
models下的模型
<?php
/**
* Description of third_login_model
*新浪接口授权及登录model
* @author
*/
class third_login_model extends CI_Model{
//put your code here
private $sina=array();
private $qq =array();
private $users ='';
private $third='';
public function __construct() {
parent::__construct();
// $this->l = DIRECTORY_SEPARATOR;
$this->load->database();
$this->load->library('session');
include_once APPPATH."/libraries"."/saetv2.ex.class.php";
$this->third = $this->db->dbprefix.'_third_login';
$this->users = $this->db->dbprefix.'_user_reg';
$this->config->load("sina_conf");
$this->sina= $this->config->item("sina_conf");
}
/**
* @uses : 新浪微博登录
* @param :
* @return : $sina_url----登录地址
*/
public function sina_login(){
$obj = new SaeTOAuthV2($this->sina['App_Key'],$this->sina['App_Secret']);
$sina_url = $obj->getAuthorizeURL( $this->sina['WB_CALLBACK_URL'] );
return $sina_url;
}
/**
* @uses : 登录后,通过返回的code值,获取token,实现授权完成,然后获取用户信息
* @param : $code
* @return : $user_message--用户信息
*/
public function sina_callback($code){
$obj = new SaeTOAuthV2($this->sina['App_Key'],$this->sina['App_Secret']);
if (isset($code)) {
$keys = array();
$keys['code'] = $code;
$keys['redirect_uri'] = $this->sina['WB_CALLBACK_URL'];
try {
$token = $obj->getAccessToken( 'code', $keys ) ;//完成授权
} catch (OAuthException $e) {
}
}
$c = new SaeTClientV2($this->sina['App_Key'], $this->sina['App_Secret'], $token['access_token']);
$ms =$c->home_timeline();
$uid_get = $c->get_uid();//获取u_id
$uid = $uid_get['uid'];
$user_message = $c->show_user_by_id($uid);//获取用户信息
return $user_message;
}
/**
* @uses : 查询第三方登录表
* @param : $where
* @return : 第三方登录用户记录结果集
*/
public function select_third($where) {
$result = false;
$this->db->select();
$this->db->from($this->third);
$this->db->where($where);
$query = $this->db->get();
if($query){
$result = $query->row_array();
}
return $result;
}
/**
* @uses : sina查询用户表和第三方登录表
* @param : $where
* @return : 第三方登录用户记录结果集
*/
public function select_user_name($where) {
$field ="user.id,user.password,user.username,utl.*";
$sql = "select {$field} from {$this->third} as utl "
." left join {$this->users} as user on user.id=utl.user_id"
. " where utl.sina_id={$where}";
$query = $this->db->query($sql);
$result = $query->row_array();
return $result;
}
/**
* @uses : qq查询用户表和第三方登录表
* @param : $where
* @return : 第三方登录用户记录结果集
*/
public function select_user_qqname($where) {
$field ="user.id,user.password,user.username,utl.*";
$sql = "select {$field} from {$this->third} as utl "
." left join {$this->users} as user on user.id=utl.user_id"
. " where utl.qq_id='{$where}'";
$query = $this->db->query($sql);
$result = $query->row_array();
return $result;
}
// public function insert_third($datas){
// if (!is_array($datas)) show_error ('wrong param');
// $res ='';
// $res = $this->db->insert($this->third, $datas);
// return $res;
// }
//
// public function up_third($datas) {
//
// }
public function binding_third($datas) {
if (!is_array($datas)) show_error ('wrong param');
if($datas['sina_id']==0 && $datas['qq_id']==0) return;
$resa ='';
$resb ='';
$resa = $this->select_third(array("user_id"=>$datas['user_id']));
$temp =array(
"user_id"=>$datas['user_id'],
"sina_id"=>$resa['sina_id']!=0 ? $resa['sina_id'] : $datas['sina_id'],
"qq_id" => $resa['qq_id']!=0 ? $resa['qq_id'] : $datas['qq_id'],
);
if($resa){
$resb = $this->db->update($this->third, $temp,array("user_id"=>$datas['user_id']));
}else{
$resb = $this->db->insert($this->third,$temp);
}
if($resb) {
$this->session->unset_userdata('sina_id');
$this->session->unset_userdata('qq_id');
}
return $resb;
}
}
libraries/tencent/oauth.php在下载附件中
新浪配置文件
application/config/sina_conf.php
<?php
$config["sina_conf"] = array( //测试机
"App_Key" => '1498005339',
"App_Secret" =>'f1c6277a38b39f764c76a1190750a6dc',
"WB_CALLBACK_URL" => 'http://.../callback.php'
);
根目录下的回调地址 callback.php
<?php
/*
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
//新浪微博登录回调入口文件,将路径转移到login/callback方法里,并将code值传过去
$code ='';
$url = '';
$str ='';
$code = $_REQUEST['code'];
$url = "/login/callback";
$str = "<!doctype html>
<html>
<head>
<meta charset=\"UTF-8\">
<title>自动跳转</title>
</head>
<body>";
$str .="<form action=\"{$url}\" method=\"post\" id=\"form\" autocomplete='off'>";
$str .="<input type='hidden' name='code' value='{$code}'>";
$str .="</form>
</body>
</html>
<script type=\"text/javascript\">
document.getElementById('form').submit();
</script>";
echo $str;
请求的方法
//流程原理:
// 1.通过code获得access_token通过授权,并获取用户的信息(包括用户u_id)
// 2.查询第三方登录表,如果存在用户id,查询用户表,如果邮箱已经激活,就直接登录,如果没有激活,提示用户去邮箱激活帐号
// 3.查询第三方登录表,如果不存在用户id,分2种情况,一:用户在平台已经有帐号了,这时需要把平台user_reg用户id绑定到第三方登录表,然后就让客户登录
// 二:如果用户在平台没有帐号,跳转至注册页面注册,注册的同时,信息写入uer_reg表,同时也把用户id写入第三方登录表进行绑定
public function callback(){
header("content-type: text/html; charset=utf-8");
$this->load->model("user_reg_model","user_reg");
$code = $_REQUEST['code'];//code值由入口文件callback.php传过来
$arr =array();
$arr = $this->third->sina_callback($code);//通过授权并获取用户信息(包括u_id)
$res = $this->third->select_third(array("sina_id"=>$arr['id']));
if(!empty($res)){
$user_info = $this->user_reg->user_detect(array("id"=>$res['user_id']));
if($user_info['status']){
echo "<script>alert('您登陆的账号还未激活');location='/login/index';</script>";die();
}
$datas = $this->third->select_user_name($arr['id']);
// echo "<pre>";print_r($datas);die();
$uname = $datas['username'];
$password = $datas['password'];
$this->load->model("login_model","login");
$this->login->validation($uname,$password);
echo "<script>alert('登录成功!');location='/user_center'</script>";die();
}else{
$this->session->set_userdata('sina_id',$arr['id']);
echo "<script>if(!confirm('是否在平台注册过用户?')){location='/register/index'}else{location='/login'};</script>";
}
}
- libraries.tar.gz (23.8 KB)
- 下载次数: 27
发表评论
-
phpimageeditor 修改后自用
2015-03-23 16:31 629下载组件phpimageeditor; $ vim phpi ... -
authcode加密解密
2015-03-02 00:14 1445function authcode_config($strin ... -
javascript checebox 全选与反选
2015-01-21 09:34 833// .checkzeny是checkbox标签类 sele ... -
数组与对象的转换
2014-05-29 00:04 602//php 对象到数组转换 private funct ... -
数组递归方法
2014-05-29 00:02 981$items = array( 1 => arr ...
相关推荐
OAuth是一种授权框架,允许第三方应用在用户授权的情况下访问其数据,而无需获取用户的账号密码。 4. **HTTP请求与响应**:客户端与微博服务器之间的通信主要基于HTTP协议。开发者需要理解和使用HTTP请求方法(如...
内容概要:本文详细介绍了利用MATLAB和CPLEX求解器实现的电热综合能源市场双层出清模型。该模型分为上下两层,上层旨在最大化能源集线器的收益,下层则致力于最小化电力和热力市场的生产和出清成本。文中不仅提供了详细的代码示例,还解释了各个模块的功能及其背后的理论依据,如MPEC(数学规划与均衡约束)、KKT条件的应用等。此外,文章强调了代码的模块化设计和良好的注释,使得新手能够轻松理解和修改代码。最终,通过与参考文献的对比,证明了模型的有效性和准确性。 适用人群:适用于对综合能源系统优化感兴趣的初学者和有一定经验的研究人员。 使用场景及目标:①帮助研究人员理解电热综合能源市场的运作机制;②为开发更复杂的能源市场模型提供基础;③通过实际案例和数据验证模型的正确性和实用性。 其他说明:文章还提到了一些高级应用和技术细节,如储能参数调整对市场策略的影响、极端天气条件下不同能源设备的表现差异等。
内容概要:本文详细介绍了利用MATLAB实现电动汽车多目标优化调度策略,旨在通过智能充放电管理实现电网的削峰填谷。具体来说,该策略将经济成本、峰谷差和负荷波动三个目标融合为一个综合优化目标,并通过严格的约束条件确保电池安全运行。文中展示了如何使用YALMIP和CPLEX求解器对大规模电动汽车群进行快速有效的调度,最终显著改善了电网负荷曲线并降低了电池损耗成本。 适合人群:从事电力系统优化、电动汽车调度研究的专业人士,以及对智能电网感兴趣的科研人员和技术开发者。 使用场景及目标:适用于需要优化电网负荷曲线、减少峰谷差、稳定负荷波动的实际应用场景。主要目标是在不影响用户体验的前提下,最大化电网效率和经济效益。 其他说明:文中提供了详细的代码片段和参数选择依据,帮助读者理解和复现实验结果。此外,还讨论了一些调参技巧和潜在改进方向,如引入光伏预测等。
内容概要:本文详细介绍了基于三菱R系列PLC的多工位转盘机项目的编程实践。作者摒弃传统的梯形图编程方式,采用ST语言进行面向对象编程,构建了一个类似工业级框架的模板程序。主要内容包括:使用结构体进行参数传递,确保参数管理和调试的便捷性;通过功能块(FB)封装工位控制逻辑,实现模块化和复用;采用层次化的程序架构,使主程序简洁高效;设计完善的异常处理机制,提高系统的稳定性和维护性。此外,文章还展示了如何快速扩展新工位以及热替换功能的优势。 适合人群:具备PLC编程基础,尤其是熟悉三菱PLC的工程师和技术人员。 使用场景及目标:适用于需要优化PLC编程流程、提升代码可读性和维护性的工程项目。目标是通过面向对象编程思想,实现PLC程序的模块化、标准化和高效化。 其他说明:文中提供了多个具体的代码示例,帮助读者更好地理解和应用所介绍的技术和方法。同时,强调了良好的架构设计对于提高开发效率和应对需求变更的重要性。
内容概要:该论文聚焦于6G通信中20-100GHz频段的电磁场(EMF)暴露评估问题,提出了一种基于自适应可重构架构神经网络(RAWA-NN)的预测框架。该框架通过集成权重分析模块和优化模块,能够自动优化网络超参数,显著减少训练时间。模型使用70%的前臂数据进行训练,其余数据用于测试,并用腹部和股四头肌数据验证模型泛化能力。结果显示,该模型在不同参数下的相对差异(RD)在前臂低于2.6%,其他身体部位低于9.5%,可有效预测皮肤表面的温升和吸收功率密度(APD)。此外,论文还提供了详细的代码实现,涵盖数据预处理、权重分析模块、自适应优化模块、RAWA-NN模型构建及训练评估等内容。 适合人群:从事电磁兼容性研究、6G通信技术研发以及对神经网络优化感兴趣的科研人员和工程师。 使用场景及目标:①研究6G通信中高频段电磁暴露对人体的影响;②开发更高效的电磁暴露评估工具;③优化神经网络架构以提高模型训练效率和预测精度。 其他说明:论文不仅提出了理论框架,还提供了完整的代码实现,方便读者复现实验结果。此外,论文还讨论了未来的研究方向,包括扩展到更高频段(如300GHz)的数据处理、引入强化学习优化超参数、以及实现多物理场耦合的智能电磁暴露评估系统。建议读者在实际应用中根据具体需求调整模型架构和参数,并结合真实数据进行验证。
内容概要:本文详细介绍了如何使用FB284功能块在西门子S7-1200/1500 PLC中实现对V90 PN伺服系统的控制。主要内容涵盖基础配置、主动回零、定位控制以及速度点动等功能的具体实现方法和技术细节。文中不仅提供了具体的代码示例,还分享了许多实际调试过程中积累的经验教训,帮助读者更好地理解和应用这些技术。 适合人群:从事工业自动化领域的工程师和技术人员,特别是那些需要进行伺服控制系统开发和维护的专业人士。 使用场景及目标:适用于需要精确位置控制的应用场合,如生产线上的物料搬运、加工中心的位置控制等。通过学习本文,读者能够掌握使用FB284功能块实现伺服控制的基本技能,提高工作效率并减少调试时间。 其他说明:文章强调了正确的参数配置对于伺服系统正常运行的重要性,并提供了一些常见问题及其解决方案。此外,还提到了一些优化建议,如合理的速度设置和平滑启动等措施,有助于提升系统的稳定性和可靠性。
内容概要:本文是北京金融科技产业联盟发布的《基于数据空间的金融数据可信流通研究报告》,探讨了金融数据可信流通的现状、挑战和发展前景。文章首先介绍了金融数据在数字化转型中的重要性及其面临的隐私保护和安全挑战。接着,文章详细阐述了数据空间的概念及其发展历程,尤其是可信数据空间(TDM)在我国的发展情况。文中还深入分析了金融数据可信流通的典型应用场景、关键技术和方案架构,如数据访问控制、数据使用控制、智能合约、数据脱敏等。最后,文章展示了多个典型场景应用案例,如中信银行总分行数据流通管控、工银金租数据流通、银联安全生物特征支付等,并总结了当前可信数据空间建设中存在的法规、技术、标准和商业模式挑战,提出了相应的政策建议。 适用人群:金融行业从业者、数据安全管理人员、政策制定者、科技研发人员等。 使用场景及目标:①理解金融数据可信流通的重要性和挑战;②学习可信数据空间的关键技术和应用场景;③探索金融数据可信流通的具体实践案例;④了解当前可信数据空间建设的瓶颈和未来发展方向。 其他说明:本文不仅提供了详尽的技术和应用分析,还提出了具体的政策建议,有助于推动金融数据可信流通的健康发展。阅读本文可以帮助读者深入了解金融数据安全保护和高效利用的最佳实践,为相关政策和技术的发展提供参考。
内容概要:本文详细介绍了智能车环境中静态和动态风险场模型的构建及其在MATLAB中的实现。首先,通过椭圆模型建立静态风险场,模拟车辆周围的碰撞风险分布,重点在于椭圆参数的选择和坐标变换的应用。其次,动态风险场考虑了车辆之间的相对运动,利用相对速度和方向因子来评估风险值的变化。两者结合形成综合风险场,用于优化车辆的轨迹规划。文中还讨论了模型的实际应用案例,如在弯道和十字路口场景中的表现,并提供了可视化技巧和调试经验。 适合人群:从事智能车研究、自动驾驶算法开发的研究人员和技术人员,以及对MATLAB编程有一定基础的学习者。 使用场景及目标:①帮助研究人员理解和实现智能车环境中的风险场模型;②提供具体的MATLAB代码示例,便于实际应用和调试;③通过实例展示风险场模型在复杂交通场景中的应用效果。 其他说明:文章不仅涵盖了理论推导和代码实现,还包括了实际测试中的经验和教训,有助于读者更好地掌握和应用这一技术。
少儿编程scratch项目源代码文件案例素材-scratch格斗游戏引擎.zip
基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业),个人经导师指导并认可通过的高分设计项目,评审分99分,代码完整确保可以运行,小白也可以亲自搞定,主要针对计算机相关专业的正在做大作业的学生和需要项目实战练习的学习者,可作为毕业设计、课程设计、期末大作业,代码资料完整,下载可用。 基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业)基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业)基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业)基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业)基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业)基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业)基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业)基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业)基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业)基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业)基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业)基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业)基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业)基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业)基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业)基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业)基于Python的天气预测和天气可视化项目源码+文档说明(高分毕设/大作业
少儿编程scratch项目源代码文件案例素材-3D环境.zip
内容概要:本文详细介绍了如何利用Simplorer和Maxwell进行电机控制系统的联合仿真。主要内容分为四个部分:一是搭建电机场路耦合主电路,包括选择合适的电机模型、功率器件及其他必要元件,并进行正确的连接和参数设置;二是实现矢量控制SVPWM算法,涵盖SVPWM模块的搭建、参数设置以及信号连接;三是讨论仿真文件的可复制性和电机模型替换的具体步骤;四是总结联合仿真的优势及其应用价值。通过这种方式,不仅可以深入理解电机的工作原理,还可以优化控制算法,提升电机性能。 适合人群:从事电机控制研究和技术开发的工程师、研究人员,特别是对电机场路耦合仿真感兴趣的从业者。 使用场景及目标:适用于需要进行电机控制系统设计和优化的场合,如工业自动化、电动汽车等领域。主要目标是掌握Simplorer和Maxwell联合仿真的方法,提高电机控制系统的效率和可靠性。 其他说明:文中提供了大量实例代码和操作提示,有助于读者更好地理解和实践相关技术。同时强调了一些常见错误和解决办法,帮助初学者避开陷阱。
内容概要:本文详细介绍了基于西门子200smart PLC和昆仑通态触摸屏构建的锅炉换热站自动化系统的设计与实现。主要内容涵盖模拟量采集与处理、水泵切换逻辑、时间段控温和Modbus通讯控制等方面的技术细节及其优化措施。文中不仅展示了具体的编程技巧,如SCALE指令用于工程量转换、状态矩阵实现水泵故障记忆、时钟指令配合SFC20块搬移指令进行时间段控温等,还分享了许多实际调试过程中遇到的问题及解决方案,如通过硬件和软件滤波减少信号跳变、调整Modbus通讯参数提高稳定性等。 适合人群:从事工业自动化领域的工程师和技术人员,特别是对PLC编程和系统集成有一定经验的人士。 使用场景及目标:适用于小型工业自动化项目的开发与维护,旨在帮助技术人员掌握如何高效地搭建稳定可靠的自动化控制系统,提升系统的可靠性和易用性。 其他说明:作者通过亲身经历分享了许多宝贵的实战经验和教训,强调了理论与实践相结合的重要性。对于希望深入了解PLC编程和工业自动化应用的人来说,本文提供了丰富的参考资料和技术指导。
内容概要:本文详细介绍了T型三电平逆变器的空间矢量脉宽调制(SVPWM)开环控制实现过程。首先阐述了T型三电平逆变器的基本拓扑结构和特点,接着通过MATLAB、Python和C语言代码展示了SVPWM的具体实现步骤,包括矢量分区、作用时间计算、PWM波生成以及中性点平衡处理。文中还讨论了一些常见的工程实践技巧,如零矢量分配策略、死区时间设置等,并提供了仿真测试结果和波形分析。 适合人群:从事电力电子、新能源项目开发的技术人员,尤其是对SVPWM算法感兴趣的工程师。 使用场景及目标:适用于需要理解和实现T型三电平逆变器SVPWM开环控制的工程项目。目标是帮助读者掌握SVPWM算法的核心原理和技术细节,能够在实际项目中进行有效的算法实现和优化。 其他说明:文中引用了几篇经典的学术文献作为理论支持,同时提供了一些实用的调试建议和注意事项,有助于提高读者的实际操作能力。
麒麟arm64系统需要的qt 的离线环境,参考:https://blog.csdn.net/m0-53485135/article/details/135544602
内容概要:本文详细介绍了在一个物流中心托盘堆垛项目中使用的三菱Q系列PLC和QD77MS16模块的配置和应用。主要内容涵盖硬件架构、伺服参数配置、定位数据表、HMI设计、安全回路设计以及调试经验和技巧。文中提供了具体的代码示例,如梯形图、结构化文本和VBS脚本,展示了如何实现精确的位置控制和平滑的运动轨迹。此外,还讨论了常见的调试问题及其解决方案,如轴号选择、信号抖动、同步移动时的轴间碰撞等。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是熟悉三菱PLC系统的从业者。 使用场景及目标:适用于需要深入了解三菱Q系列PLC和QD77MS16模块的应用场景,帮助工程师优化堆垛机控制系统的设计和调试,提高系统的可靠性和稳定性。 其他说明:本文不仅提供理论知识,还包括大量实战经验和具体代码示例,有助于读者更好地理解和应用相关技术。
内容概要:本文详细介绍了基于STM32F407的电池管理系统(BMS)设计方案,重点探讨了SOC均衡的实现方法和技术细节。硬件方面,使用LTC6804进行12节锂电池的电压采集,LTC3300实现高效的双向主动均衡。软件部分涵盖了SOC算法的实现,包括安时积分法和开路电压校正,并讨论了LTC6804和LTC3300的具体控制代码。此外,文章分享了许多实际开发中的经验和教训,如PCB布局注意事项、通信时序优化等。 适合人群:从事电池管理系统开发的技术人员,尤其是有一定嵌入式开发经验的研发人员。 使用场景及目标:适用于电动车、储能系统等领域,旨在提高电池管理系统的可靠性和效率,确保电池组的安全运行和延长使用寿命。 其他说明:文章不仅提供了详细的硬件和软件设计指导,还包括了大量实用的经验总结和调试技巧,帮助开发者避免常见错误。
内容概要:本文详细介绍了基于西门子S7-1500 PLC和库卡机器人的汽车焊接自动化系统。系统涵盖PLC控制、机器人通信、HMI配置、多工位转台控制、SEW电机变频控制及多种运行模式。文中通过具体代码实例解释了各组件的工作原理及其相互协作的方式,强调了通讯协议、PID控制、触摸屏交互设计、异常处理机制等方面的技术细节。此外,还分享了许多来自实际项目的经验和技巧,如参数优化、安全防护措施等。 适合人群:从事工业自动化控制、PLC编程、机器人集成等相关工作的工程师和技术人员。 使用场景及目标:适用于学习和理解大型工业自动化系统的构建与实现,尤其是汽车制造行业的焊接生产线。目标是帮助读者掌握PLC与机器人通信、HMI配置、设备控制等核心技术,提升实际项目开发能力。 其他说明:文章不仅提供了详细的理论讲解,还包括大量实战经验和代码片段,有助于读者深入理解并应用于实际工作中。同时,文中提到的一些最佳实践和注意事项也能为后续维护和优化提供指导。
少儿编程scratch项目源代码文件案例素材-Scratch 卡牌游戏.zip