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

Android中Acition和Category常量表

Action

Action常量 对应字符串 简单说明
ACTION_MAIN android.intent.action.MAIN 应用程序入口
ACTION_VIEW android.intent.action.VIEW 显示指定数据
ACTION_ATTACH_DATA android.intent.action.ATTACH_DATA 指定某块数据将被附加到其它地方
ACTION_EDIT android.intent.action.EDIT 编辑指定数据
ACTION_PICK android.intent.action.PICK 从列表中选择某项并返回所选的数据
ACTION_CHOOSER android.intent.action.CHOOSER 显示一个Activity选择器
ACTION_GET_CONTENT android.intent.action.GET_CONTENT 让用户选择数据,并返回所选数据
ACTION_DIAL android.intent.action.DIAL 显示拨号面板
ACTION_CALL android.intent.action.CALL 直接向指定用户打电话
ACTION_SEND android.intent.action.SEND 向其他人发送数据
ACTION_SENDTO android.intent.action.SENDTO 向其他人发送消息
ACTION_ANSWER android.intent.action.ANSWER 应答电话
ACTION_INSERT android.intent.action.INSERT 插入数据
ACTION_DELETE android.intent.action.DELETE 删除数据
ACTION_RUN android.intent.action.RUN 运行维护
ACTION_SYNC android.intent.action.SYNC 执行数据同步
ACTION_PICK_ACTIVITY android.intent.action.PICK_ACTIVITY 用于选择Activity
ACTION_SEARCH android.intent.action.SEARCH 执行搜索
ACTION_WEB_SEARCH android.intent.action.WEB_SEARCH 执行Web搜索
ACTION_FACTORY_TEST android.intent.action.FACTORY_TEST 工厂测试的入口点

Category

Category 常量对应字符串 简单说明
CATEGORY_DEFAULT android.intent.category.DEFAULT 默认的Category
CATEGORY_BROWSABLE android.intent.category.BROWSABLE 指定该Activity能被浏览器安全调用
CATEGORY_TAB android.intent.category.TAB 指定Activity作为TabActivity的Tab页
CATEGORY_LAUNCHER android.intent.category.LAUNCHER Activity显示顶级程序列表中
CATEGORY_INFO android.intent.category.INFO 用于提供包信息
CATEGORY_HOME android.intent.category.HOME 设置该Activity随系统启动而运行
CATEGORY_PREFERENCE android.intent.category.PREFERENCE 该Activity是参数面板
CATEGORY_TEST android.intent.category.TEST 该Activity是一个测试
CATEGORY_CAR_DOCK android.intent.category.CAR_DOCK 指定手机被插入汽车底座(硬件)时运行该Activity
CATEGORY_DESK_DOCK android.intent.category.DESK_DOCK 指定手机被插入桌面底座(硬件)时运行该Activity
CATEGORY_CAR_MODE android.intent.category.CAR_MODE 设置该Activity可在车载环境下使用

android开发:使用RandomAccessFile来输出日志

RandomAccessFile是用来访问那些保存数据记录的文件的,你就可以用seek( )方法来访问记录,并进行读写了。这些记录的大小不必相同;但是其大小和位置必须是可知的。但是该类仅限于操作文件。

RandomAccessFile不属于InputStream和OutputStream类系的。实际上,除了实现DataInput和DataOutput接口之外(DataInputStream和DataOutputStream也实现了这两个接口),它和这两个类系毫不相干,甚至不使用InputStream和OutputStream类中已经存在的任何功能;它是一个完全独立的类,所有方法(绝大多数都只属于它自己)都是从零开始写的。这可能是因为RandomAccessFile能在文件里面前后移动,所以它的行为与其它的I/O类有些根本性的不同。总而言之,它是一个直接继承Object的,独立的类。

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