×

人脸验证解锁的安全系统开源分享

消耗积分:0 | 格式:zip | 大小:0.03 MB | 2022-10-26

李丽华

分享资料个

描述

欢迎,好奇的朋友!我们生活在一个互联网革命的时代,现在比以往任何时候都更容易进行实验和创新,以提出可以对全球数百万人产生积极影响的绝妙想法。

曾经想为您家中的架子、抽屉、衣柜或门增加一点额外的安全性吗?当谈到使用互联网进行创新时,在我们可用的数千个平台和工具中,有几个脱颖而出的是. 在这个项目中,我们将修改一个标准架子,使其拥有一个使用人脸验证解锁的安全系统。我们将C#构建一个Windows 窗体应用程序,它可以存储、验证和解锁受信任的面孔。用于面部验证和Bolt IoT Cloud API,用于与 Bolt WiFi 模块和 Arduino 进行通信。我们将 Bolt WiFi 模块与Arduino Uno连接,它将控制伺服电机锁定/解锁门。ArduinoBolt IoTFacePlusPlus API

兴奋的?让我们开始吧。

背景

我将这个项目作为由 Internshala Trainings 举办的创新挑战和物联网培训的一部分。他们的培训有助于了解处理 API 服务、面向对象编程以及最重要的是使用 Bolt WiFi 模块的基础知识。可以在此处找到作为本次培训的一部分完成的 Capstone 项目的概要在这个项目的开发过程中,很多这些概念都派上了用场。因此,非常感谢 Internshala 团队让这一切成为可能。

第 1 步:构建软件

我们将使用 Visual Studio 构建一个 Windows 窗体应用程序。此应用程序在 Windows 机器上运行,将负责管理授权人脸、使用 FacePlusPlus API 验证人脸以及与 Bolt WiFi 模块通信。我们将使用 C# 进行编码。

启动 Visual Studio 并创建新的 Windows 窗体应用程序项目。如果您完全不熟悉 Visual Studio,我建议您学习使用 Visual Studio 进行 Windows 窗体应用程序开发的基础知识。都是很好的入门资源。

在本教程中,我将仅使用项目中执行主要和重要功能的代码片段来解释代码。浏览整个代码将是乏味且不必要的,因为其中大部分都是不言自明且有据可查的。

我们的 Visual Studio 项目将 3 个库用于各种目的。他们是:

  • AForge .NET:一种流行的 .NET 框架,用于 Windows 中的图像处理。我们使用它从网络摄像头捕获图像。
  • Bolt IoT API .NET:我用 C# 编写的非官方客户端库,用于与 Bolt Cloud API 进行通信。
  • Newtonsoft JSON:一种流行的 .NET 高性能 JSON 框架。用于在我们的项目中解析 A​​PI 响应。

注意:为了清楚了解上述 API 中不同方法的用法,请参阅各自的文档here herehere

入门

在开始编码之前,我们需要设置一些东西。

1. Bolt Cloud API 凭证

如果您还没有,请访问cloud.boltiot.com并设置一个帐户。登录后,将您的 WiFi 模块与 Bolt Cloud 链接。为此,请在您的手机上下载 Bolt IoT 设置应用程序。按照应用程序中的说明将您的设备与您的帐户相关联。这涉及将 Bolt 与本地 WiFi 网络配对。成功链接后,您的仪表板将显示您的设备。您现在可以从仪表板获取您的设备 IDAPI 密钥。

2. FacePlusPlus API 凭证

我们在这个项目中依赖的另一个 API 服务是FacePlusPlus API它是一个免费平台,提供各种图像识别服务。我们将其用于面部识别。创建一个帐户并转到 FacePlusPlus 控制台。转到下方并单击记下新生成的API KeyAPI Secret API KeyApps+Get API Key

 
poYBAGNYe5CASqNCAAAZOaOqW8g988.png
 

现在您应该准备好以下内容:

private readonly string BOLT_DEVICE_ID = "BOLTXXXXXX";
private readonly string BOLT_API_KEY = "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX";
  
private readonly string FPP_API_KEY = "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX";
private readonly string FPP_API_SECRET = "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX";

我们创建一个名为 的 Bolt 类的新全局实例myBolt,通过它我们将与 WiFi 模块进行所有未来的通信:

myBolt = new Bolt(BOLT_API_KEY, BOLT_DEVICE_ID);

也就是说,现在让我们看看我们的应用程序如何执行一些核心功能。

1. 锁定/解锁门

我们设计了这样的威廉希尔官方网站 ,当数字引脚 0 为HIGH时,门应该被锁定,而当数字引脚 3 为 时HIGH,门应该被解锁。稍后我们讨论威廉希尔官方网站 原理图时会更清楚地说明这一点。

对于锁定,我们使用DigitalMultiWrite库中的方法将HIGH值写入 D0 并将 LOW 值写入 D3。这将向 Arduino 发出锁门信号。同样对于解锁,我们将LOW值写入 D0 并将HIGH值写入 D3。这将向 Arduino 发出解锁门的信号。我们将在本教程后面讨论 Arduino 代码和威廉希尔官方网站 设计。

执行锁定的代码:

private async Task LockDoor()
{
   MultiPinConfig multiPinConfig = new MultiPinConfig();
   MultiPinConfig.AddPinState(DigitalPins.D0, DigitalStates.High); //Lock Signal 
   multiPinConfig.AddPinState(DigitalPins.D3, DigitalStates.Low); //Unlock Signal
  
   await myBolt.DigitalMultiWrite(multiPinConfig);
  
   multiPinConfig = new MultiPinConfig();
   multiPinConfig.AddPinState(DigitalPins.D0, DigitalStates.Low); //Lock Signal 
   multiPinConfig.AddPinState(DigitalPins.D3, DigitalStates.Low); //Unlock Signal
  
   await myBolt.DigitalMultiWrite(multiPinConfig);
}

执行解锁的代码:

private async Task UnlockDoor()
{
   MultiPinConfig multiPinConfig = new MultiPinConfig();
   multiPinConfig.AddPinState(DigitalPins.D0, DigitalStates.Low); //Lock Signal 
   multiPinConfig.AddPinState(DigitalPins.D3, DigitalStates.High); //Unlock Signal
  
   await myBolt.DigitalMultiWrite(multiPinConfig);
  
   multiPinConfig = new MultiPinConfig();
   multiPinConfig.AddPinState(DigitalPins.D0, DigitalStates.Low); //Lock Signal 
   multiPinConfig.AddPinState(DigitalPins.D3, DigitalStates.Low); //Unlock Signal
  
   await myBolt.DigitalMultiWrite(multiPinConfig);
}

2. 添加/删除可信面孔

可信人脸的图像数据被编码为 Base64 字符串,并存储在本地机器中。还存储了每个人脸的对应名称列表。在我们的程序中,要添加人脸,我们首先验证当前帧中是否有可用的人脸。我们使用FacePlusPlus的Detect API来执行此操作。它返回一个 JSON 响应,其中包含检测到的面部特征。如果没有检测到人脸,则响应将是[]一旦检测到人脸,我们就会保存图像的 base64 编码字符串和相应的名称。这是添加可信面孔的视频演示。

演示 - 添加受信任的面孔。
 

去除脸部非常简单。按删除按钮将从保存的列表中删除图像数据和名称。

添加和保存人脸信息的代码:

//Converting image to base64 string and adding it to the list. 
ImageDataList.Add(ImageToBase64((Image)PreviewBox.Image.Clone()));
//Adding name of the face to the list
NameList.Add(FaceNameTextBox.Text.Trim());
  
//Saves the face image data as a base encoded string, along with its name
Properties.Settings.Default.Base64ImageData = ImageDataList;
Properties.Settings.Default.FaceNames = NameList;
Properties.Settings.Default.Save();

删除人脸信息的代码:

//Removing face information at specified position in the list
NameList.RemoveAt(e.RowIndex);
ImageDataList.RemoveAt(e.RowIndex);
  
//Saving the the list after removal of a face
Properties.Settings.Default.FaceNames = NameList;
Properties.Settings.Default.Base64ImageData = ImageDataList;
Properties.Settings.Default.Save();

查看附加项目中的代码,其中每行中都将流程解释为注释,以便有一个清晰的想法。

3.人脸验证

我们通过使用FacePlusPlus 中的比较 API来验证人脸是否可信。在此过程中,我们线性迭代保存列表中的每个人脸,并将其与捕获的图像进行比较。如果 API 返回超过 80% 的置信度,我们将解锁门。

进行此比较的代码如下所示:

WebClient client = new WebClient();
  
byte[] response = client.UploadValues("https://api-us.faceplusplus.com/facepp/v3/compare", new NameValueCollection()
{
    { "api_key", FPP_API_KEY },
    { "api_secret", FPP_API_SECRET },
    { "image_base64_1", face1Base64},
    { "image_base64_2", face2Base64}
    });
});
  
string confidence = JObject.Parse(System.Text.Encoding.UTF8.GetString(response))["confidence"].ToString();

WebClient.UploadValues方法将请求连同要比较的两个人脸的 base64 编码人脸数据和我们的 API 凭据一起发送到 FacePlusPlus API。使用Newtonsoft JSON库解析响应并confidence获取值。阅读比较 API文档以清楚地理解参数。

4. 听钟线

我们计划提供一个物理按钮,类似于呼叫铃按钮,以便用户可以在看着摄像头时按下以解锁门。为了使这成为可能,我们需要创建一个新的专用线程来持续侦听铃声按钮按下事件。

在本教程的后面,我们将看到如何使用按钮以及按下按钮时它将如何使 Bolt WiFi 模块HIGH的 D4 引脚。现在,我们只假设上述情况。所以在这个线程中,我们不断地计算 D4 引脚的值。如果是,我们将其作为铃声事件并进行人脸捕获和验证。DigitalReadHIGH

这是将在铃声侦听线程上连续运行的代码:

while (ListenForBell)
{
    Response R = await myBolt.DigitalRead(DigitalPins.D4);
    if (R.Value == "1")
    {
        RingBell_Click(null, null);
        Thread.Sleep(2000);
    }
    Thread.Sleep(2000);
}

我们在每次迭代之间停止并等待 2 秒。否则会很快耗尽 Bolt Cloud API 的使用配额。

第 2 步:构建 Visual Studio 项目

在此处下载整个项目在 Visual Studio 中打开文件。解决方案加载后,打开文件并使用您的 API 凭据更新代码。按名为“开始”的绿色播放按钮,构建并运行程序。 Facebolt Doorlock.slnForm1.cs

该程序允许您从连接到系统的摄像头设备中进行选择,并查看来自摄像头的实时信息。您可以添加/删除受信任的面孔。开始人脸监控。一旦程序验证了您的 Bolt 设备的连接性,您就可以直接从程序中按铃或锁门。

 
 
 
 
poYBAGNYe5OAJSdXAAGF6uafi8k360.png
 
1 / 3修改 API 凭证并运行
 

如果您现在对程序中人脸验证、锁定和解锁的工作方式感到困惑,没关系。一旦我们看到威廉希尔官方网站 原理图设计和Arduino代码,就会变得更加清晰。最后,我还将分解每个操作的事件流。

第 3 步:威廉希尔官方网站 设计和 Arduino 代码

在我们的威廉希尔官方网站 中,我们打算实现以下功能:

  • 分别用于锁定和解锁门状态的红色和绿色 LED 指示灯。
  • 一个按钮,就像一个呼叫铃开关。按下时,我们的 WinForms 应用程序应验证面部并在成功进行面部身份验证后打开门。
  • 另一个按钮来锁门。
  • 在门铃响起和门锁时发出蜂鸣声的蜂鸣器。

我们项目的威廉希尔官方网站 连接如下图所示:

 
 
 
 
pYYBAGNYe5aAIlJ7AAIFsldKn6U870.png
 
1 / 2威廉希尔官方网站 连接
 

如果您还没有,请从此处下载 Arduino IDE并将您的 Arduino 连接到系统。在上传代码之前,请确保您已在 IDE 设置中设置了正确的 Arduino 模型和端口。

Arduino代码:

#include 
  
#define ServoPin 4
#define LockSignalPin 2
#define UnLockSignalPin 3
#define BellButtonPin 5
#define LockButtonPin 8
#define RingBellSignalPin 6
#define BuzzerPin 7
#define GreenLedPin 9
#define RedLedPin 10
  
Servo myServo;
  
void setup() 
{
    pinMode(LockSignalPin, INPUT);
    pinMode(UnLockSignalPin, INPUT);
    pinMode(BellButtonPin, INPUT);
    pinMode(LockButtonPin, INPUT);
  
    pinMode(BuzzerPin, OUTPUT);
    pinMode(RedLedPin, OUTPUT);
    pinMode(GreenLedPin, OUTPUT);
    pinMode(RingBellSignalPin, OUTPUT);
  
    digitalWrite(RedLedPin, LOW);
    digitalWrite(GreenLedPin, LOW);
    digitalWrite(RingBellSignalPin, LOW);
  
    myServo.attach(ServoPin);
    Serial.begin(9600);
}
  
void loop() 
{
    int lockButton, lock, unlock, bell;
    char snum[5];
  
    lock = digitalRead(LockSignalPin);
    unlock = digitalRead(UnLockSignalPin);
    
    // Check if lock signal from Bolt is HIGH
    if(lock == HIGH)
    {
        // Turn motor to locked position
        myServo.write(120);
        
        // Set LED indications
        digitalWrite(GreenLedPin, LOW);
        digitalWrite(RedLedPin, HIGH);
  
        // Buzz locking sound
        digitalWrite(BuzzerPin, HIGH);
        delay(1000);
        digitalWrite(BuzzerPin, LOW);
        delay(1000);
    }
    // Check if unlock signal from Bolt is HIGH
    else if(unlock == HIGH)
    {
        // Turn motor to unlocked position
        myServo.write(0);
        
        // Set LED indications
        digitalWrite(GreenLedPin, HIGH);
        digitalWrite(RedLedPin, LOW);
        delay(2000);
    }
  
    bell = digitalRead(BellButtonPin);
    if(bell == HIGH) // User pressed bell ring betton
    {
        // Signal Bolt that ring button was pressed
        digitalWrite(RingBellSignalPin, HIGH);
  
        // A calling bell sound pattern !
        digitalWrite(BuzzerPin, HIGH); 
        delay(100);
        digitalWrite(BuzzerPin, LOW);
        delay(20);
        digitalWrite(BuzzerPin, HIGH);
        delay(200);
        digitalWrite(BuzzerPin, LOW);
        delay(100);
        digitalWrite(BuzzerPin, HIGH);
        delay(100);
        digitalWrite(BuzzerPin, LOW);
        delay(20);
        digitalWrite(BuzzerPin, HIGH);
        delay(200);
        digitalWrite(BuzzerPin, LOW);
        delay(1500);
  
        // Turn off the signal
        digitalWrite(RingBellSignalPin, LOW);
    }
  
    lockButton = digitalRead(LockButtonPin);
    if(lockButton == HIGH) // User pressed lock betton
    {
        // Turn motor to locked position
        myServo.write(120);
        
        // Set LED indications
        digitalWrite(GreenLedPin, LOW);
        digitalWrite(RedLedPin, HIGH);
  
        // Buzz locking sound
        digitalWrite(BuzzerPin, HIGH);
        delay(1000);
        digitalWrite(BuzzerPin, LOW);
    }
}

事件流

现在我们已经准备好 WinForm 应用程序和 Arduino 设计,让我们深入研究代码并探索每个操作的控制流程。

1. 响铃按钮按下

 
poYBAGNYe5uAGtyxAAMdtKaPu0E910.png
响铃按钮按下 - 事件流
 

2. 锁定按钮按下

 
pYYBAGNYe52AK_ygAADG05FpawU461.png
锁定按钮按下 - 事件流
 

上述两个操作也可以直接从 Windows 窗体应用程序执行。

在这里,我们可以观察到Bolt WiFi 模块作为 Windows 窗体应用程序和 Arduino 之间的重要无线接口。Bolt Cloud API 的使用使我们能够扩展我们的项目并在 Android 等其他平台上构建应用程序,并使用我们的手机解锁门!这种灵活性是物联网和 Bolt 平台的力量所在。

现在我们已经完成了软件设计部分,让我们继续构建一个可锁定的门机制。

第 4 步:构建硬件

我有一个鞋架,所以在这个项目中,我将用它来演示锁具。您可以使用架子、门或衣柜或任何具有可破解锁定机制的东西。这真的取决于你。

我们需要建立一个耦合机构,将我们的伺服电机与锁连接起来。为此,我的想法是使用一个瓶子和另一个瓶盖的截断颈部。将瓶颈连接到伺服电机,将盖子连接到锁上。然后我们将使用尼龙线将它们连接起来。每当电机转动时,这将导致锁定/解锁动作。

所需的瓶盖上钻有一个孔,如下图所示。我们将把它连接到鞋架的锁轴上。

 
pYYBAGNYe6aAeZUOAAaHKfOxOTA478.jpg
 
1 / 2带钻孔的瓶盖
 

另一个瓶子的盖子必须连接到伺服电机上。我们使用铜线将盖子连接到电机的转轴。

 
 
 
 
poYBAGNYe6uAGJOuAAa_nwBk9KI914.jpg
 
1 / 3伺服电机轴使用铜线连接到瓶盖
 

现在我们需要将这两者结合起来。为此,我们使用尼龙线。使用所需长度的线制作一个环,并将线连接到两个盖子上。

 
 
 
 
pYYBAGNYe7CAdGDgAAdUllWZbBI837.jpg
 
1 / 2使用金属垫圈将环形螺纹连接到盖子上
 

一旦耦合,它们可以引起相互旋转的动作:

使用尼龙线连接的瓶盖
 

现在我们已经准备好转动机构,是时候进入锁并修复我们的瓶颈了。我们在上面钻了一个孔,所以我们需要做的就是从机架上拧下锁轴,将瓶颈放在上面,然后重新拧紧锁。

将瓶颈固定在锁定机构上
 

现在唯一要做的就是将伺服电机固定在鞋架上。我们将使用热胶枪将电机密封到机架上。

 
 
 
 
pYYBAGNYe7aAX5qXAAoihwwCBqA943.jpg
 
1 / 2将伺服电机连接到鞋架
 

调整好螺纹长度并充分拧紧后,我们就完成了最后的设置。如下图所示,伺服电机可以正确锁门和开锁!

 
 
 
 
 
1 / 2使用尼龙螺纹的联轴器锁和电机
 

您不一定必须使用瓶颈 - 螺纹耦合方法。使用最适合和方便您的锁系统的任何方法。

幸运的是,我在机架的正确位置开了一个小口。这使我能够轻松地连接伺服电机。经过一些装饰工作和贴标后,我们最终的智能鞋架现已准备就绪。

 
 
 
 
poYBAGNYe7yANIcwAAj2Vs3XWCY625.jpg
 
1 / 6智能鞋架
 

我们现在都准备好了。剩下要做的就是启动威廉希尔官方网站 ,在 WinForms 应用程序上添加一个受信任的面孔,并享受我们门上的人脸锁安全性。您需要同时为 Arduino 和 Bolt WiFi 模块供电。我使用 10000 毫安时的移动电源为他们俩供电。我使用的网络摄像头是 Microsoft LifeCam VX-800。它很旧,但仍然比笔记本电脑的相机好。请查看演示视频。它详细显示了我们项目的工作。

结论

哈夫..那是相当长的。该项目是由 Bolt IoT 提供支持的 Internshala 物联网培训的成果。虽然这个项目非常简单,但它向我们展示了物联网的潜力以及它如何让人们的日常生活更轻松。

无论如何..这对我来说是一次很棒的学习经历。我希望你们会喜欢构建它,我很高兴看到你们会想出什么新的创新。最后,我衷心感谢 Internshala 和 Bolt IoT 的培训团队使这项事业成为可能。

这是一个包装!

 

 


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

评论(0)
发评论

下载排行榜

全部0条评论

快来发表一下你的评论吧 !

'+ '

'+ '

'+ ''+ '
'+ ''+ ''+ '
'+ ''+ '' ); $.get('/article/vipdownload/aid/'+webid,function(data){ if(data.code ==5){ $(pop_this).attr('href',"/login/index.html"); return false } if(data.code == 2){ //跳转到VIP升级页面 window.location.href="//m.obk20.com/vip/index?aid=" + webid return false } //是会员 if (data.code > 0) { $('body').append(htmlSetNormalDownload); var getWidth=$("#poplayer").width(); $("#poplayer").css("margin-left","-"+getWidth/2+"px"); $('#tips').html(data.msg) $('.download_confirm').click(function(){ $('#dialog').remove(); }) } else { var down_url = $('#vipdownload').attr('data-url'); isBindAnalysisForm(pop_this, down_url, 1) } }); }); //是否开通VIP $.get('/article/vipdownload/aid/'+webid,function(data){ if(data.code == 2 || data.code ==5){ //跳转到VIP升级页面 $('#vipdownload>span').text("开通VIP 免费下载") return false }else{ // 待续费 if(data.code == 3) { vipExpiredInfo.ifVipExpired = true vipExpiredInfo.vipExpiredDate = data.data.endoftime } $('#vipdownload .icon-vip-tips').remove() $('#vipdownload>span').text("VIP免积分下载") } }); }).on("click",".download_cancel",function(){ $('#dialog').remove(); }) var setWeixinShare={};//定义默认的微信分享信息,页面如果要自定义分享,直接更改此变量即可 if(window.navigator.userAgent.toLowerCase().match(/MicroMessenger/i) == 'micromessenger'){ var d={ title:'人脸验证解锁的安全系统开源分享',//标题 desc:$('[name=description]').attr("content"), //描述 imgUrl:'https://'+location.host+'/static/images/ele-logo.png',// 分享图标,默认是logo link:'',//链接 type:'',// 分享类型,music、video或link,不填默认为link dataUrl:'',//如果type是music或video,则要提供数据链接,默认为空 success:'', // 用户确认分享后执行的回调函数 cancel:''// 用户取消分享后执行的回调函数 } setWeixinShare=$.extend(d,setWeixinShare); $.ajax({ url:"//www.obk20.com/app/wechat/index.php?s=Home/ShareConfig/index", data:"share_url="+encodeURIComponent(location.href)+"&format=jsonp&domain=m", type:'get', dataType:'jsonp', success:function(res){ if(res.status!="successed"){ return false; } $.getScript('https://res.wx.qq.com/open/js/jweixin-1.0.0.js',function(result,status){ if(status!="success"){ return false; } var getWxCfg=res.data; wx.config({ //debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId:getWxCfg.appId, // 必填,公众号的唯一标识 timestamp:getWxCfg.timestamp, // 必填,生成签名的时间戳 nonceStr:getWxCfg.nonceStr, // 必填,生成签名的随机串 signature:getWxCfg.signature,// 必填,签名,见附录1 jsApiList:['onMenuShareTimeline','onMenuShareAppMessage','onMenuShareQQ','onMenuShareWeibo','onMenuShareQZone'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 }); wx.ready(function(){ //获取“分享到朋友圈”按钮点击状态及自定义分享内容接口 wx.onMenuShareTimeline({ title: setWeixinShare.title, // 分享标题 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享给朋友”按钮点击状态及自定义分享内容接口 wx.onMenuShareAppMessage({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 type: setWeixinShare.type, // 分享类型,music、video或link,不填默认为link dataUrl: setWeixinShare.dataUrl, // 如果type是music或video,则要提供数据链接,默认为空 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到QQ”按钮点击状态及自定义分享内容接口 wx.onMenuShareQQ({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口 wx.onMenuShareWeibo({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到QQ空间”按钮点击状态及自定义分享内容接口 wx.onMenuShareQZone({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); }); }); } }); } function openX_ad(posterid, htmlid, width, height) { if ($(htmlid).length > 0) { var randomnumber = Math.random(); var now_url = encodeURIComponent(window.location.href); var ga = document.createElement('iframe'); ga.src = 'https://www1.elecfans.com/www/delivery/myafr.php?target=_blank&cb=' + randomnumber + '&zoneid=' + posterid+'&prefer='+now_url; ga.width = width; ga.height = height; ga.frameBorder = 0; ga.scrolling = 'no'; var s = $(htmlid).append(ga); } } openX_ad(828, '#berry-300', 300, 250);