2018-02-07 10:54:10 qq_30519365 阅读数 685

1 IOS 的请求和加载http的处理:参考了此篇博文 https://segmentfault.com/a/1190000002933776

注意:
NSAppTransportSecurity

NSAllowsArbitraryLoads

2.当android 遇到https;

由于RectNative 底层请求网络用的OKhttp默认是无法加载https 的请求
处理稍微复杂:需要修改Android 原生代码处理所有https的协议

package com.wx_hcx_rn;

import android.app.Application;

import com.facebook.react.ReactApplication;
import com.facebook.react.ReactNativeHost;
import com.facebook.react.ReactPackage;
import com.facebook.react.modules.network.OkHttpClientProvider;
import com.facebook.react.shell.MainReactPackage;
import com.facebook.soloader.SoLoader;

import java.util.Arrays;
import java.util.List;

public class MainApplication extends Application implements ReactApplication {

  private final ReactNativeHost mReactNativeHost = new ReactNativeHost(this) {
    @Override
    public boolean getUseDeveloperSupport() {
      return BuildConfig.DEBUG;
    }

    @Override
    protected List<ReactPackage> getPackages() {
      return Arrays.<ReactPackage>asList(
          new MainReactPackage()
      );
    }

    @Override
    protected String getJSMainModuleName() {
      return "index";
    }
  };

  @Override
  public ReactNativeHost getReactNativeHost() {
    return mReactNativeHost;
  }

  @Override
  public void onCreate() {
    super.onCreate();
//修改okhttpclient
    OkHttpClientProvider.replaceOkHttpClient(HttpsOkHttpClient.initCustomOkHttpClient());
    SoLoader.init(this, /* native exopackage */ false);
  }
}

下面是自定义的okhttpclient

package com.wx_hcx_rn;

import com.facebook.react.modules.network.OkHttpClientProvider;
import com.facebook.react.modules.network.ReactCookieJarContainer;

import java.security.SecureRandom;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
import java.util.concurrent.TimeUnit;

import javax.net.ssl.HostnameVerifier;
import javax.net.ssl.KeyManager;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSession;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;

import okhttp3.OkHttpClient;

/**
 * .::::.
 * .::::::::.
 * :::::::::::  FUCK YOU
 * ..:::::::::::'
 * '::::::::::::'
 * .::::::::::
 * '::::::::::::::..
 * ..::::::::::::.
 * ``::::::::::::::::
 * ::::``:::::::::'        .:::.
 * ::::'   ':::::'       .::::::::.
 * .::::'      ::::     .:::::::'::::.
 * .:::'       :::::  .:::::::::' ':::::.
 * .::'        :::::.:::::::::'      ':::::.
 * .::'         ::::::::::::::'         ``::::.
 * …:::           ::::::::::::'              ``::.
 * ```` ':.          ':::::::::'                  ::::..
 * '.:::::'                    ':'````..
 * * 作者:jiangnanyizhou on 2018/2/6 22:40
 * 邮箱:373654981@qq.com
 */

public class HttpsOkHttpClient {
    /**
     * react native默认不支持https请求,这里提供支持https的OKHttpClient
     * @return
     */
    public static OkHttpClient initCustomOkHttpClient(){
        OkHttpClient.Builder client = new OkHttpClient.Builder()
                .connectTimeout(0, TimeUnit.MILLISECONDS)
                .readTimeout(0, TimeUnit.MILLISECONDS)
                .writeTimeout(0, TimeUnit.MILLISECONDS)
                .cookieJar(new ReactCookieJarContainer());

        OkHttpClient.Builder builder = OkHttpClientProvider.enableTls12OnPreLollipop(client);
        builder.sslSocketFactory(getSSLSocketFactory())
                .hostnameVerifier(new HostnameVerifier() {
                    @Override
                    public boolean verify(String hostname, SSLSession session) {
                        return true; //忽略所有的认证,直接返回了true
                    }
                });
        return builder.build();
    }

    private static SSLSocketFactory getSSLSocketFactory() {
        TrustManager[] trustAllCerts = new TrustManager[]{new X509TrustManager() {
            public void checkClientTrusted(X509Certificate[] chain, String authType) throws
                    CertificateException {
            }

            public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
            }

            public X509Certificate[] getAcceptedIssuers() {
                return new X509Certificate[0];
            }
        }};
        SSLSocketFactory sslSocketFactory = null;

        try {
            SSLContext sslContext = SSLContext.getInstance("TLS");
            sslContext.init((KeyManager[])null, trustAllCerts, new SecureRandom());
            sslSocketFactory = sslContext.getSocketFactory();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return sslSocketFactory;
    }
}
2014-02-20 15:08:25 iteye_17129 阅读数 136

        苹果的企业开发证书,可以不经app store,直接发布到自己的网站上。其他人可以直接下载安装。但前提要用苹果自带的浏览器(safari)才能下载,其他浏览器不能识别该协议。

        一、制作证书

       打开Keychain Access工具,把Keychain的配置改为如下图:


并从菜单中选择Keycahin Access->Certificate Assistant->Request a Certificate From a Certificate Authority...如下图所示:


 填写必要的信息,生成证书保存在桌面或其他地方,等会要用到:




 
 二、生成并安装证书

        用企业版的apple id登陆苹果开发者中心: https://developer.apple.com, 登陆后选择对应的选项,上传之前生成的证书文件,如下图:


 

 生成证书文件后,下载下来,双击打开即安装。

三、增加APP ID

四、生成Profiles文件

在开发中心点击Provisioning Profiles中的Distribution, 点击“+”,增加Profiles。APP ID选择刚才增加的。如图
 

添加好之后,就可以下载下来,把它拖到Xcode中。或是拖到Organizer中。如图:



 

五、发布应用

在XCode的Targets中选择签名:



 在XCode的菜单Product->Archive中选择打包。打包时要把iPad或是iphone接到电脑上,并选择目标是iPad或是iphone才能成功。



 

 

 

2017-10-09 10:46:42 a910577347 阅读数 4670

在iOS开发中,有时会有跳转系统设置界面的需求,例如提示用户打开蓝牙或者WIFI,提醒用户打开推送或者位置权限等。在iOS6之后,第三方应用需要跳转系统设置界面,需要在URL type中添加一个prefs值,如下图:
需要设置prefs


QjIfMvb.png!web.png


设置跳转有三种方式,每一种的使用场景都不同。 并且你在跳转到系统中自己应用下面设置的时候,你的应用要提前至少申请了某一个权限,如通知,定位等。否则,会引起崩溃。

  • 方式一:prefs:root=某项服务
  • 方式二:prefs:root=bundleID
  • 方式三: UIApplicationOpenSettingsURLString
    本篇针对iOS7、iOS8、iOS9、iOS10,来介绍其中区别。

一、跳转方法

iOS系统版本 < 10.0

NSURL *url= [NSURL URLWithString:@"prefs:root=LOCATION_SERVICES"];
if( [[UIApplication sharedApplication]canOpenURL:url] ) {
   [[UIApplication sharedApplication]openURL:url];
}

iOS系统版本 >= 10.0

if( [[UIApplication sharedApplication]canOpenURL:url] ) {
    [[UIApplication sharedApplication]openURL:url options:@{}completionHandler:^(BOOL        success) {
    }];
}

可以看出,跳转方法非常简单。本文重点讲解url 怎么设置

二、跳转到哪里去?(系统的设置,系统中自己应用下面的设置)

  • 方式一:

    iOS系统版本 <= iOS7 , 只能跳转到 系统设置页面

    NSURL *url= [NSURL URLWithString:@"prefs:root=LOCATION_SERVICES"];

    跳转到: 隐私-定位服务。
    prefs:root=某项服务

    系统设置:prefs:root=INTERNET_TETHERING
    WIFI设置:prefs:root=WIFI
    蓝牙设置:prefs:root=Bluetooth
    系统通知:prefs:root=NOTIFICATIONS_ID
    通用设置:prefs:root=General
    显示设置:prefs:root=DISPLAY&BRIGHTNESS
    壁纸设置:prefs:root=Wallpaper
    声音设置:prefs:root=Sounds
    隐私设置:prefs:root=privacy
    蜂窝网路:prefs:root=MOBILE_DATA_SETTINGS_ID
    音乐:prefs:root=MUSIC
    APP Store:prefs:root=STORE
    Notes:prefs:root=NOTES
    Safari:prefs:root=Safari
    Music:prefs:root=MUSIC
    photo":prefs:root=Photos

    这种跳转方式,都是跳转到系统的设置界面。

  • 方式二 :

    iOS系统版本 >= iOS8 ,支持跳转到第三方应用的设置界面中
    使用prefs:root=bundleID ,bundleID是你第三方应用工程的唯一ID
    局限性:只支持iOS8,iOS9系统,在iOS10系统上,不会跳转。 在iOS7系统上,仅仅只是跳转到设置应用,不推荐使用。

    如果需要继续向项目内层进行跳转,可以通过添加path路径的方式,如下:

    关于本机:prefs:root=General&path=About
    软件升级:prefs:root=General&path=SOFTWARE_UPDATE_LINK
    日期时间:prefs:root=General&path=DATE_AND_TIME
    Accessibility:prefs:root=General&path=ACCESSIBILITY
    键盘设置:prefs:root=General&path=Keyboard
    VPN:prefs:root=General&path=VPN
    壁纸设置:@"prefs:root=Wallpaper
    声音设置:prefs:root=Sounds
    隐私设置:prefs:root=privacy
    APP Store:prefs:root=STORE
    还原设置:prefs:root=General&path=Reset
    应用通知:prefs:root=NOTIFICATIONS_ID&path=应用的boundleId

    更多参数字段自己查询

  • 方式三

    iOS系统版本 >= iOS10,支持跳转到自己应用设置,不支持跳转到系统设置

    NSURL *url = [NSURL URLWithString:UIApplicationOpenSettingsURLString];

    UIApplicationOpenSettingsURLString字段,是在iOS8上才提供的,支持iOS8,iOS9,iOS10系统,推荐使用。
    iOS系统版本>= iOS10,支持跳转到自己应用设置,不支持跳转到系统设置
    只认

    NSURL *url = [NSURL URLWithString:UIApplicationOpenSettingsURLString];

    跳转。
    而 prefs:root=bundleID和 prefs:root=服务 都将不起作用。

总结一下:

  • 方式一:prefs:root=某项服务 适用于 小于 iOS10的系统;
  • 方式二:prefs:root=bundleID 适用于 大于等于iOS8系统,小于iOS10的系统
  • 方式三:UIApplicationOpenSettingsURLString 适用于 大于等于iOS8的系统

参考链接:http://www.jianshu.com/p/767c409c50e6

2017-09-08 17:47:17 zhangxiweicaochen 阅读数 348

error: Embedded binary is not signed with the same certificate as the parent app. Verify the embedded binary target's code sign settings match the parent app's

我遇到产生这个的原因是:



之前因为权限的问题改成了始终信任,导致报这个错。应该是权限问题(推测),知道原理的可以在评论贴一下。我改成使用系统默认就OK了。需要clean一下x-code。之前试了N多都不行 1.更换重新生成证书 2.捣鼓配置



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