app微信登录swift
2017-04-05 11:49:06 qq_31901919 阅读数 2030

一. 第一步:下载微信SDK
包的内容如下:
这里写图片描述
二. 工程配置:

1.配置URL scheme
这里写图片描述

2.加入白名单
这里写图片描述

3.倒入必要的SDK
这里写图片描述

三. 代码:
好了,准备工作已经完成,下面开始写代码了
在AppDelegate里面:

func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
        // Override point for customization after application launch.


        /**  微信  */

        WXApi.registerApp(WX_APPID, enableMTA: true)

        return true
}

func application(_ app: UIApplication, open url: URL, options: [UIApplicationOpenURLOptionsKey : Any] = [:]) -> Bool {

        WXApi.handleOpen(url, delegate: self)
        return true
    }

func application(_ application: UIApplication, open url: URL, sourceApplication: String?, annotation: Any) -> Bool {

        WXApi.handleOpen(url, delegate: self)
        return true
}

/**  微信会调  */
func onResp(_ resp: BaseResp!) {
        if resp.errCode == 0 && resp.type == 0 {//授权成功
            let response = resp as! SendAuthResp
            NotificationCenter.default.post(name: NSNotification.Name(rawValue: "WXLoginSuccessNotification"), object: response.code)
        }

}

在登录界面:

override func viewDidLoad() {
    super.viewDidLoad()
    // Do any additional setup after loading the view,    typically from a nib.
    NotificationCenter.default.addObserver(self,selector: #selector(WXLoginSuccess(notification:)),name:   NSNotification.Name(rawValue: "WXLoginSuccessNotification"),object: nil)
}

//微信登录
@IBAction func wxLoginBtnAction(_ sender: UIButton) {
    let urlStr = "weixin://"
    if UIApplication.shared.canOpenURL(URL.init(string: urlStr)!) {
        let red = SendAuthReq.init()
        red.scope = "snsapi_message,snsapi_userinfo,snsapi_friend,snsapi_contact"
        red.state = "\(arc4random()%100)"
        WXApi.send(red)
    }else{
        if #available(iOS 10.0, *) {
            UIApplication.shared.open(URL.init(string: "http://weixin.qq.com/r/qUQVDfDEVK0rrbRu9xG7")!, options: [:], completionHandler: nil)
        } else {
            // Fallback on earlier versions
            UIApplication.shared.openURL(URL.init(string: "http://weixin.qq.com/r/qUQVDfDEVK0rrbRu9xG7")!)
        }
    }
}

/**  微信通知  */
func WXLoginSuccess(notification:Notification) {

    let code = notification.object as! String
    let requestUrl = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=\(WX_APPID)&secret=\(WX_APPSecret)&code=\(code)&grant_type=authorization_code"

    DispatchQueue.global().async {

        let requestURL: URL = URL.init(string: requestUrl)!
        let data = try? Data.init(contentsOf: requestURL, options: Data.ReadingOptions())

        DispatchQueue.main.async {
            let jsonResult = try! JSONSerialization.jsonObject(with: data!, options: JSONSerialization.ReadingOptions.mutableContainers) as! Dictionary<String,Any>
            let openid: String = jsonResult["openid"] as! String
            let access_token: String = jsonResult["access_token"] as! String
            self.getUserInfo(openid: openid, access_token: access_token)
        }
    }
}

/**  获取用户信息  */
func getUserInfo(openid:String,access_token:String) {
    let requestUrl = "https://api.weixin.qq.com/sns/userinfo?access_token=\(access_token)&openid=\(openid)"

    DispatchQueue.global().async {

        let requestURL: URL = URL.init(string: requestUrl)!
        let data = try? Data.init(contentsOf: requestURL, options: Data.ReadingOptions())

        DispatchQueue.main.async {
            let jsonResult = try! JSONSerialization.jsonObject(with: data!, options: JSONSerialization.ReadingOptions.mutableContainers) as! Dictionary<String,Any>
            print(jsonResult)

        }
    }
}

好了,微信用户信息我们已经拿到了,下面只需要把这些信息发送给后台想怎么登就怎么登,哈哈哈!

2016-09-27 09:41:27 wei_chong_chong 阅读数 878

参考:https://my.oschina.net/realfighter/blog/704612

审核不允许有自动更新的功能按钮。不然审核通不过。

但是我们可以把更新功能做成一个隐含的。不带更新界面不就ok了

(其实还有一个更狠的,审核的时候把更新按钮隐藏,审核通过后再显示更新按钮):审核通过后由服务端发送一个信号显示更新按钮就行了。6不6


今天要做的是检测更新,提醒用户有新版本就行了。

获取当前app版本号

let currentVersion = NSBundle.mainBundle().infoDictionary!["CFBundleShortVersionString"]as!String

获取历史版本号,如果没有就为“”

let sandboxVersion =  NSUserDefaults.standardUserDefaults().objectForKey("CFBundleShortVersionString")as? String ??""

比较当前版本和以前版本

if currentVersion.compare(sandboxVersion) == NSComparisonResult.OrderedDescending {

存储当前的版本到沙盒

NSUserDefaults.standardUserDefaults().setObject(currentVersion, forKey:"CFBundleShortVersionString")

获取到的当前版本 > 之前的版本 =有新版本

     returntrue

}

//获取到的当前版本 <=之前的版本 = 没有新版本

return false




2017-03-13 12:41:10 weixin_33932129 阅读数 3

如何通过通过纯粹的代码,而不依赖于Xcode的StoryBoard,来完成一个App?

首先做些操作性的工作,具体过程是这样的:

  1. 打开xcode

  2. 创建一个Single View App

Xcode会进入主要编辑界面。此时,我们打开AppDelegate.swift文件然后覆盖源代码为如下:

    import UIKit
    @UIApplicationMain
    class AppDelegate: UIResponder, UIApplicationDelegate {
        var window : UIWindow?
        func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
            window = UIWindow()
            window!.rootViewController = UIViewController()
            window!.rootViewController!.view.backgroundColor = .blue
            window!.makeKeyAndVisible()
            return true
        }
    }

运行后发现手机(或者仿真器)满屏的蓝色背景就说明成功了。

一起来看看代码。

我们需要导入UIKit:


    import UIKit

框架UIKit用来构造和管理用户界面、响应用户交互和系统事件。既然需要创建App,引入UIKit是第一件需要做的工作。

接着查看AppDelegate类。它实现协议UIApplicationDelegate,且必须被标记为@UIApplicationMain,两者配合就设置了App的程序入口点。AppDelegate实现了此协议中规定的函数:

 func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool 

这样,UIKit就会在完成App启动调用此函数,从而App可以再次实现自己的初始化逻辑。

在本案例中,我们在启动函数中创建了window实例,它是UIWindow的实例。代码随即把window属性的rootViewController设置为UIViewController的实例。

为了可视化的看到我们的工作成果,我们设置UIViewController的背景色为蓝色,设置的方式就是把属性view背景色设置为蓝色,此属性是类UIView的实例。

这样,我们完成了最基本的一个UI界面。

window和view是构建UI的关键构造块,因此有必要澄清下概念。

每个应用都有一个window,这个window并没有任何外观形象,每个view都是被window包含在内的,事件处理也是首先路由到相应的window对象然后被导向到对应的视图。

View定义了一个屏幕上的矩形区域,并且管理此区域的内容和用户交互。window通过一个rootViewController的属性view开始关联,然后在此view内可以通过addSubView加入更多的子视图来完成UI的构建。

随后我们会接触更多的view类型,实际上按钮(UIButton)、标签(UILabel)等可以看到和交互的控件都是视图的子类,View的使用时非常广泛的。

可能很多人会觉得AppDelegate这个名字过于冗长。为此我们得了解一个叫做Delegate的设计模式。Delegate是一个简单而强大的设计模式,可以让其中一个对象委托一部分功能给另外一个对象。做法就是发起对象持有委托对象的实例,并在适当的时间发起消息给委托对象,告诉委托对象将要发生的事件或者已经发生的事件。委托对象可以更新用户界面或者更新自己的状态作为响应。

在此案例中,关于委托牵涉到了两个类包括UIApplication、AppDelegate,以及一个协议为UIApplicationDelegate,UIApplication委托事件给AppDelegate,这里的委托事件就是:

    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool

以便让在UIApplicationDelegate的对象可以完成自己的初始化代码。UIApplication和UIApplicationDelegate之间可以建立一个协议,此协议规定两者之间可以委托的具体内容,此协议就是UIApplicationDelegate规定的,可以通过手册了解此协议的更多资料。

这样,我们了解到了建造一个App涉及到的最少的类:UIApplication、UIApplicationDelegate、UIWindow、UIViewController,以及UIKit大量使用的委托设计模式,未来的文字将会以此为垫脚石。

2016-03-31 11:20:00 weixin_34347651 阅读数 3

1. 使用 interface Builder 快速构建原型 --- Main.storyboard

2.  CocoaPods :包管理工具,管理 Objective-C 的组件

Cocoa: 苹果提供给开发者的 API,通过 Cocoa 我们就可以操作 Mac OS 系统了

安装: $ sudo gem install cocoapods

3. core location 用于 编写基于地理位置信息的 App

import CoreLocation

转载于:https://www.jianshu.com/p/308c1a554f0f

2017-11-08 15:03:37 luolianxi 阅读数 1154
Swift有对应的版本更新库(Siren),有需要的可以参考和使用。

iOS开发中,有时会有这种需求,在AppStore上出现新版本时,应用内弹窗提示用户更新.自动提示更新的实现方案分为两种:

第一种,自己服务器提供一个接口,通过请求,获取app的相关的版本信息,如:是否需要更新,以及更新的地址等信息
第二种,就是利用苹果的appstore 提供的相关api进行查询更新.http://itunes.apple.com/cn/lookup?id=你的APPId

采用方案1,实现逻辑:

1: 向自己服务器请求当前版本信息
2: 和App当前版本进行比较,如果返回的版本比当前本地版本新,弹窗并显示更新日志,根据点击的按钮,控制用户跳转到AppStore更新

简单实现
效果图:



具体代码实现

[javascript] view plain copy
  1. struct VersionInfo {  
  2.     var url: String        //下载应用URL  
  3.     var title: String       //title  
  4.     var message: String       //提示内容  
  5.     var must_update: Bool  //是否强制更新  
  6.     var version: String     //版本  
  7. }  
  8.       
  9. class VersionManager: NSObject {  
  10.       
  11.     //本地版本  
  12.    private static func localVersion() -> String? {  
  13.         return Bundle.main.infoDictionary?["CFBundleShortVersionString"] as? String  
  14.     }  
  15.       
  16.     static func versionUpdate() {  
  17.         //1 请求服务端数据,并进行解析,得到需要的数据  
  18.         //2 版本更新  
  19.         handleUpdate(VersionInfo(url: "应用下载地址", title: "有新版本啦!", message: "提示更新内容,解决了xxx等一系列问题,新增了xxx等功能!", must_update: false, version: "3.5"))  
  20.     }  
  21.       
  22.     /// 版本更新  
  23.    private static func handleUpdate(_ info: VersionInfo) {  
  24.         guard let localVersion = localVersion()else { return }  
  25.         if isIgnoreCurrentVersionUpdate(info.version) { return }  
  26.         if versionCompare(localVersion: localVersion, serverVersion: info.version) {  
  27.             let alert = UIAlertController(title: info.title, message: info.message, preferredStyle: .alert)  
  28.             let update = UIAlertAction(title: "立即更新", style: .default, handler: { action in  
  29.                 UIApplication.shared.open(URL(string: info.url)!)  
  30.             })  
  31.             alert.addAction(update)  
  32.             if !info.must_update { //是否强制更新  
  33.                 let cancel = UIAlertAction(title: "忽略此版本", style: .cancel, handler: { action in  
  34.                     UserDefaults.standard.set(info.version, forKey: "IgnoreCurrentVersionUpdate")  
  35.                 })  
  36.                 alert.addAction(cancel)  
  37.             }  
  38.             if let vc = UIApplication.shared.keyWindow?.rootViewController {  
  39.                 vc.present(alert, animated: true, completion: nil)  
  40.             }  
  41.         }  
  42.     }  
  43.       
  44.    // 版本比较  
  45.    private static func versionCompare(localVersion: String, serverVersion: String) -> Bool {  
  46.         let result = localVersion.compare(serverVersion, options: .numeric, range: nil, locale: nil)  
  47.         if result == .orderedDescending || result == .orderedSame{  
  48.             return false  
  49.         }  
  50.             return true  
  51.     }  
  52.       
  53.     // 是否忽略当前版本更新  
  54.     private static func isIgnoreCurrentVersionUpdate(_ version: String) -> Bool {  
  55.         return UserDefaults.standard.string(forKey: "IgnoreCurrentVersionUpdate") == version  
  56.     }  
  57. }  

简单说明:
1 代码的实现很简单,上面只是简单写了一个测试数据,真正的数据需要自己在每次程序启动之后向服务端请求数据。
2 提供了获取本地版本、版本更新、版本比较、是否忽略当前版本更新等4个方法。isIgnoreCurrentVersionUpdate方法是表示当用户选择忽略版本之后下次启动程序,对于当前版本不再进行更新提示


Swift有对应的版本更新库(Siren),有需要的可以参考和使用。


swift App内购

阅读数 2944

swift -单糖app

阅读数 625

最小的Swift App

阅读数 11

Swift 书面 ToDo App

阅读数 3

没有更多推荐了,返回首页