APP生成签名

MAC下 Android签名生成keystore

1.生成证书

在终端输入
keytool -genkey -v -keystore android.keystore -alias android -keyalg RSA -validity 20000 -keystore /Users/当前用户的用户名/android_demo.keystore
如果mac没有安装Java JDK 则会提示如下信息:

安装完成之后再次在终端输入上面的命令,按照要求(如下图)填写信息.最后一个检验信息一定要填写:y 而不是:yes .网上大部分都是写的填写: yes  导致我尝试很多次一直在重复填写信息那一步.

填写信息完成之后,证书创建就完成了. 上面输入的命令里面的/Users/当前用户的用户名/android_demo.keystore 就是证书的地址.

2.查看证书信息

在终端输入命令:

keytool -list -v -keystore 证书存放地址(例如: /Users/当前用户的用户名/android_demo.keystore)

回车.输入刚才的口令密码,即可查看证书的所有信息(例如申请一些三方需要的SHA1).

 

Android平台签名证书(.keystore)生成指南

分类:HTML5+
Android证书
Android平台打包发布apk应用,需要使用数字证书(.keystore文件)进行签名,用于表明开发者身份。Android证书的生成是自助和免费的,不需要审批或付费。可以使用JRE环境中的keytool命令生成。以下是windows平台生成证书的方法:

安装JRE环境(推荐使用JRE8环境,如已有可跳过)

可从Oracle官方下载jre安装包:https://www.oracle.com/technetwork/java/javase/downloads/index.html
下面以安装目录为“C:\Program Files\Java\jre1.8.0_201”为例,实际操作时请修改为自己安装目录
建议将JRE安装路径添加到系统环境变量,已配置可跳过此章节
打开命令行(cmd),输入以下命令:

在终端输入命令:  
set PATH=%PATH%;"C:\Program Files\Java\jre1.8.0_201\bin"
  • 第一行:切换工作目录到D:路径
  • 第二行:将jre命令添加到临时环境变量中

生成签名证书

使用keytool -genkey命令生成证书:

在终端输入命令: keytool -genkey -alias testalias -keyalg RSA -keysize 2048 -validity 36500 -keystore test.keystore
  • testalias是证书别名,可修改为自己想设置的字符,建议使用英文字母和数字
  • test.keystore是证书文件名称,可修改为自己想设置的文件名称,也可以指定完整文件路径

回车后会提示:

在终端输入命令:Enter keystore password:  //输入证书文件密码,输入完成回车  
Re-enter new password:   //再次输入证书文件密码,输入完成回车  
What is your first and last name?  
  [Unknown]:  //输入名字和姓氏,输入完成回车  
What is the name of your organizational unit?  
  [Unknown]:  //输入组织单位名称,输入完成回车  
What is the name of your organization?  
  [Unknown]:  //输入组织名称,输入完成回车  
What is the name of your City or Locality?  
  [Unknown]:  //输入城市或区域名称,输入完成回车  
What is the name of your State or Province?  
  [Unknown]:  //输入省/市/自治区名称,输入完成回车  
What is the two-letter country code for this unit?  
  [Unknown]:  //输入国家/地区代号(两个字母),中国为CN,输入完成回车  
Is CN=XX, OU=XX, O=XX, L=XX, ST=XX, C=XX correct?  
  [no]:  //确认上面输入的内容是否正确,输入y,回车  

Enter key password for <testalias>  
        (RETURN if same as keystore password):  //确认证书密码与证书文件密码一样(HBuilder|HBuilderX要求这两个密码一致),直接回车就可以

以上命令运行完成后就会生成证书,路径为“D:\test.keystore”。

查看证书信息

可以使用以下命令查看:

在终端输入命令:keytool -list -v -keystore test.keystore  
Enter keystore password: //输入密码,回车

会输出以下格式信息:

在终端输入命令:Keystore type: PKCS12    
Keystore provider: SUN    

Your keystore contains 1 entry    

Alias name: test    
Creation date: 2019-10-28    
Entry type: PrivateKeyEntry    
Certificate chain length: 1    
Certificate[1]:    
Owner: CN=Tester, OU=Test, O=Test, L=HD, ST=BJ, C=CN    
Issuer: CN=Tester, OU=Test, O=Test, L=HD, ST=BJ, C=CN    
Serial number: 7dd12840    
Valid from: Fri Jul 26 20:52:56 CST 2019 until: Sun Jul 02 20:52:56 CST 2119    
Certificate fingerprints:    
         MD5:  F9:F6:C8:1F:DB:AB:50:14:7D:6F:2C:4F:CE:E6:0A:A5    
         SHA1: BB:AC:E2:2F:97:3B:18:02:E7:D6:69:A3:7A:28:EF:D2:3F:A3:68:E7    
         SHA256: 24:11:7D:E7:36:12:BC:FE:AF:2A:6A:24:BD:04:4F:2E:33:E5:2D:41:96:5F:50:4D:74:17:7F:4F:E2:55:EB:26    
Signature algorithm name: SHA256withRSA    
Subject Public Key Algorithm: 2048-bit RSA key    
Version: 3

其中证书指纹信息(Certificate fingerprints):

  • MD5
    证书的MD5指纹信息(安全码MD5)
  • SHA1
    证书的SHA1指纹信息(安全码SHA1)
  • SHA256
    证书的SHA256指纹信息(安全码SHA245)

 

1、修改keystore密码的命令(keytool为JDK带的命令行工具):

keytool -storepasswd -keystore my.keystore

2、修改keystore的alias(别名):

keytool -changealias -keystore my.keystore -alias my_name_key -destalias aliasdebugkey

3、修改alias(别名)的密码:

keytool -keypasswd -keystore my.keystore -alias aliasdebugkey

LNMP环境为PHP添加exif扩展

在使用时 php报出如下错误: Call to undefined function gemvary\exif_imagetype()

好吧,exif扩展没安装…

通过 打印phpinfo() 查看得知 mbstring 扩展是有的,exif扩展没有

982daa5b6884e1aaa66c1558ae324394.png

如果mbstring也没有,也可以参考以下exif扩展的安装过程;

安装过程基本类似的;

进入主题:

1、查看当前环境PHP的版本号和安装目录

whereis php
结果:
[root@xiaojun exif]# whereis php
php: /usr/bin/php /usr/lib64/php /etc/php.d /etc/php.ini /usr/include/php /usr/local/php /usr/share/php /usr/local/php/bin/php /usr/share/man/man1/php.1.gz

[root@xiaojun exif]# /usr/local/php/bin/php -v
PHP 7.1.7 (cli) (built: Mar 16 2018 11:06:26) ( NTS )
Copyright (c) 1997-2017 The PHP Group
Zend Engine v3.1.0, Copyright (c) 1998-2017 Zend Technologies

那么phpize的位置就是 /usr/local/php/bin/phpize

2、进入php的源码目录

#这是我电脑上的路径,得改成自己服务器上的路径
cd /www/lnmp1.4/src/php-7.1.7/ext/exif

进入扩展目录后进行初始化:

/usr/local/php/bin/phpize

命令执行后当前目录会多几个文件,只要有 configure 这个文件就行

然后再检查配置,输入:

./configure --with-php-config=/usr/local/php/bin/php-config

如果有报错说明路径不对,使用 whereis php-config 查看服务器上此文件的路径

接下来再依次执行这两个命令:

make
make install

执行完会有类似如下信息:

[root@xiaojun exif]# make install
Installing shared extensions:     /usr/local/php/lib/php/extensions/no-debug-non-zts-20160303/

这个目录就是扩展安装后的存放目录;

3、修改php.ini引入扩展

vi /usr/local/php/etc/php.ini

在最后面加入:

extension=exif.so

然后保存,重启PHP就完事了;

需要注意的是 exif.so 必须放在 mbstring.so 的后面,否则会出错;

可能出现的问题:

重启PHP时提示: NOTICE: PHP message: PHP Warning:  Module ‘mbstring’ already loaded in Unknown on line 0

意思是mbstring这个扩展已经加载过了,还尝试引入;

解决办法:

PHP加载模块有两种方式,一种是通过php.ini 加载模块,另一种是通过编译时的参数加载模块。

这里出这个提示,那么mbstring应该就是属于后者,只需要php.ini中将其注释掉就行了

;extension=mbstring.so

输入/usr/local/bin/phpize后提示: Cannot find config.m4. Make sure that you run /usr/local/bin/phpize in the top level sourc

我是将openssl扩展内的config0.m4文件改成config.m4就没提示了;

cd ../openssl
cp ./config0.m4 ./config.m4

至于为什么openssl扩展的config.m4为什么会影响到安装其它扩展,暂不得而知;