android Studio生成的APK重新签名的方法

1. 生成签名证书
使用JDK自带的keytool工具, 运行下面的命令
keytool -genkey -alias lanxinbase -keyalg RSA -validity20000 -keystore lanxinbase.com.jks

/*解释:keytool工具是Java JDK自带的证书工具
-genkey参数表示:要生成一个证书(版权、身份识别的安全证书)
-alias参数表示:证书有别名,-alias androidauto.keystore表示证书别名为:androidauto
-keyalg RSA表示加密类型,RSA表示需要加密,以防止别人盗取
-validity 20000表示有效时间20000天
-keystore lanxinbase.com.jks表示要生成的证书名称为lanxinbase.com.jks
*/
输入完回车后屏幕显示:
输入keystore密码:[密码不回显]
再次输入新密码:[密码不回显]
您的名字与姓氏是什么?
Unknown]:cheers
您的组织单位名称是什么?
Unknown]:cheers
您的组织名称是什么?
Unknown]:cheers
您所在的城市或区域名称是什么?)
Unknown]:shanghai
您所在的州或省份名称是什么?
Unknown]:shanghai
该单位的两字母国家代码是什么
Unknown]:CN
输入< ***.keystore>的主密码
(如果和keystore密码相同,按回车):

执行以上语句后在执行的目录下会生成证书文件 lanxinbase.com.jks

2. 删除之前APK文件的签名

  • 解压apk文件(我用7-ZIP 提取出来)
  • 删除解压出来文件夹中的 META-INF目录:META-INF存放签名后的CERT和MANIFEST文件,用于识别软件的签名及版权。
  • 删除文件夹后重新把解压出来的其它文件夹压缩为zip文件,然后直接把文件后缀改为apk

注意:一定要选中要压缩的文件,然后压缩成.zip 文件,zip文件必须是根目录,即 打开zip文件,就能看见压缩的文件内容,这非常重要。

3. 为APK重新生成签名

  • 将证书复制到与需要重新签名的apk文件相同的目录下
  • 进入该目录下执行以下语句

jarsigner -verbose -keystore lanxinbase.com.jks -signedjar app-release.apk app-dubug.apk lanxinbase

命令解释:
jarsigner是Java的签名工具,JDK自带
-verbose参数表示:显示出签名详细信息
-keystore表示使用当前目录中的android.keystore签名证书文件。
-signedjar app-release.apk app-dubug.apk 表示签名后生成的APK名称为app-release.apk ,未签名的APK Android软件名称为app-dubug.apk
-androidauto.keystore表示签名文件的别名,生成证书的时候有书写

执行以上操作之后在目录下生成了app-release.apk,经过自己签名的APK文件。

Git 基本操作

一、安装环境
CentOS: yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel

Debian: apt-get install libcurl4-gnutls-dev libexpat1-dev gettext libz-dev libssl-dev
二、安装Git
CentOS: yum install git-core

Debian: apt-get install git-core

三、创建基础仓库
mkdir /git/test
cd /git/test

git init –bare –shared //初始化基础仓库

四、客户端操作
git clone root@192.168.1.199:/git/test //克隆仓库

然后复制文件到 test 目录

git add * //添加所有文件
git commit -m “初始化版本”
git push //推送到服务器上
五、其他
git add [*|file] //将该文件添加到缓存
git log [–oneline] //使用 git clone 拷贝一个 Git 仓库到本地,让自己能够查看该项目,或者进行修改。
git diff [file name][–cached] //执行 git diff 来查看执行 git status 的结果的详细信息。
git clone [url] //使用 git clone 拷贝一个 Git 仓库到本地,让自己能够查看该项目,或者进行修改。
git init //用 git init 在目录中创建新的 Git 仓库。 你可以在任何时候、任何目录中这么做,完全是本地化的。
git status //查看在你上次提交之后是否有修改。
git commit [-am] //将缓存区内容添加到仓库中。
git reset HEAD //用于取消已缓存的内容。
git rm [filename] //会将条目从缓存区中移除
git mv [filename] //命令做得所有事情就是 git rm –cached 命令的操作

nginx网站被持续攻击最终防攻策略

上上个月架构全部迁移上云以后,总的来说比较稳定,业务量也上来,可爱的坏人也来了,7X24小时不停恶意攻击我的网站,第一次收到报警是网站流入流量1分钟以内连续3次超过1000000bps,换算下1M/s秒,平时没那么大流量的啊,当时刚好在朋友家玩,于赶紧开本本连vpn检查,发现全是访问同一个页面的请求,而且是正常访问http 200,应该是被恶意攻击了。

发现问题:
发现问题第一反应,赶紧将请求地址截图发给开发们看看,问问这个具体是什么?
最后得知是为短信验证码接口,据后来统计在被持续攻击的一个多小时中损失16000多条短信。

100+ WEB开发工具和资源,热门的都在了

作为Web开发者,这是好的时代,也是坏的时代。Web开发技术也在不断变化。虽然很令人兴奋,但是这也意味着Web开发人员需要要积极主动的学习新技术和新的编程语言,并愿意和渴望接受新的挑战,以适应变化。新的挑战可能会包括一些开发上的要求,如利用适应现有的框架来满足业务需求。测试一个网站,能从中知道出了哪些技术上的问题,并且我们针对这些问题进行优化和消除。便于后端的开发进程加快和测试。所以我们列出了完整的web开发所需要的工具和资源,助力开发者提高开发效率!学不止步,让我们努力成为一个优秀的开发者!

Web开发工具和资源整合

在这里说声抱歉,对于开发者开发使用的工具,我们无法一一囊括,这里是选取较为热门的工具和资源作为范例。我们希望能从中找到适合自己的工具助力自己的开发!

注:工具和资源排序不分先后。

android开发:Application、ActivityResult详解

先说说Application这个类吧,这个累在整个APP中是唯一不变的,也就是说除非APP call exit(0);否则,它的数据都是有效,相当于其他语言的超全局变量吧!

要实现Application类,首先,我们需要创建一个类:

package com.test.testapp;

import android.app.Application;

/**
 * Created by Alan on 2016/08/09 0009.
 */
public class myApplication extends Application {

    private String mUser_name;//用户名
    private String mUser_pwd;//密码

    public void onCreate() {
        super.onCreate();
        setmUser_name(null);
        setmUser_pwd(null);
    }

    public String getmUser_name(){
        return mUser_name;
    }

    public String getmUser_pwd( ){
        return mUser_pwd;
    }

    public void setmUser_name(String u){
        mUser_name = u;
    }

    public void setmUser_pwd(String u){
        mUser_pwd = u;
    }

}

上面代码,我们实现了设置用户名跟密码已经取用户名跟密码的方法,为了简单的演示,所以使用了String,如果在应用编程中,我们应该是指定其他数据类型或者是对象才对;

接着我们需要在manifest描述文件中制定我们application的类名字,只需要增加:android:name=”.myApplication”就可以了;

QQ截图20160809121937

 

创建了一个Application类,那么我们来进行初始化:

myApplication app = (myApplication) getApplication();//这一句放在MainActivity的onCreate()方法中,取得了Application类对象,然后我们调用Application类中的setmUser_name跟setmUset_pwd的方法设置用户名跟密码:
app.setmUser_name("test");
app.setmUser_pwd("123456");

接着我们会绑定一个按钮事件,使用Intent打开第二个Activity,然后使用这个Activity进行Application数据读取:
Button but = (Button) findViewById(R.id.but1);
but.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View view) {
        Intent intent = new Intent(MainActivity.this,twoActivity.class);
        startActivityForResult(intent,101);
    }
});
QQ截图20160809121924

这里面我们使用的是startActivityForResult,因为我们在调用登陆窗口的时候可能需要数据返回,所以使用startActivityForResult是一个明智的选择;

 

在第二个Activity中,我们首先是读取Application初始化的值(为了演示使用):

app = (myApplication) getApplication();

Log.d(TAG,"2User_name:"+app.getmUser_name());
Log.d(TAG,"2User_pwd:"+app.getmUser_pwd());

接着我们绑定一个回调的按钮(模拟登陆成功的按钮):
Button but = (Button) findViewById(R.id.but1);
but.setText("返回");
but.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View view) {
        Intent intent = new Intent();
        intent.putExtra("user",app.getmUser_name());
        intent.putExtra("pwd",app.getmUser_pwd());
        intent.putExtra("msg","登陆成功了");

        app.setmUser_name("2:test");
        app.setmUser_pwd("2:123456");
        setResult(100,intent);
        finish();
    }
});

我们改写MainActivity中的onActivityResult方法,用于数据处理:

protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode,resultCode,data);

    Log.d(TAG,"requestCode:"+requestCode);
    Log.d(TAG,"resultCode:"+resultCode);
    Log.d(TAG,"user:"+data.getStringExtra("user")+"\tpwd:"+data.getStringExtra("pwd")+"\tmsg:"+data.getStringExtra("msg"));


    Log.d(TAG,"User_name1:"+app.getmUser_name());
    Log.d(TAG,"User_pwd1:"+app.getmUser_pwd());
    /*
    * 可以在这里写一些逻辑处理代码
    * */

}

以下是日志输出:

QQ截图20160809121859

源代码:链接:http://pan.baidu.com/s/1gfhpAb5 密码:nt49

123418
 
Copyright © 2008-2021 lanxinbase.com Rights Reserved. | 粤ICP备14086738号-3 |