Java 利用图形化界面做出验证IP地址的程序

package com.gogogo

import java.awt.EventQueue;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;

import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JTextField;
import javax.swing.border.EmptyBorder;

public class CheckIPAddress extends JFrame {
    
    private JPanel contentPane;
    private JTextField ipField;
    
    /**
     * Launch the application.
     */
    public static void main(String[] args) {
        EventQueue.invokeLater(new Runnable() {
            public void run() {
                try {
                    CheckIPAddress frame = new CheckIPAddress();
                    frame.setVisible(true);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        });
    }
    
    /**
     * Create the frame.
     */
    public CheckIPAddress() {
        setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        setBounds(100, 100, 280, 128);  //位置和大小
        contentPane = new JPanel();
        contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
        setContentPane(contentPane);
        contentPane.setLayout(null);
        
        JLabel lblip = new JLabel("请输入IP地址");
        lblip.setBounds(12, 14, 92, 15);
        contentPane.add(lblip);
        
        ipField = new JTextField();
        ipField.setBounds(100, 10, 141, 25);
        contentPane.add(ipField);
        
        JButton button = new JButton("\u9A8C\u8BC1");
        button.addActionListener(new ActionListener() {
            public void actionPerformed(ActionEvent e) {
                do_button_actionPerformed(e);
            }
        });
        button.setBounds(66, 57, 93, 23);
        contentPane.add(button);
    }
    
    protected void do_button_actionPerformed(ActionEvent e) {
        String text = ipField.getText();// 获取用户输入
        String info = matches(text);// 对输入文本进行IP验证
        JOptionPane.showMessageDialog(null, info);// 用对话框输出验证结果
    }
    
    /**
     * 验证ip是否合法
     * 
     * @param text
     *            ip地址
     * @return 验证信息
     */
    public String matches(String text) {
        if (text != null && !text.isEmpty()) {
            // 定义正则表达式
            String regex = "^(1\\d{2}|2[0-4]\\d|25[0-5]|[1-9]\\d|[1-9])\\."
                    + "(1\\d{2}|2[0-4]\\d|25[0-5]|[1-9]\\d|\\d)\\."
                    + "(1\\d{2}|2[0-4]\\d|25[0-5]|[1-9]\\d|\\d)\\."
                    + "(1\\d{2}|2[0-4]\\d|25[0-5]|[1-9]\\d|\\d)$";
            // 判断ip地址是否与正则表达式匹配
            if (text.matches(regex)) {
                // 返回判断信息
                return text + "\n是一个合法的IP地址!";
            } else {
                // 返回判断信息
                return text + "\n不是一个合法的IP地址!";
            }
        }
        // 返回判断信息
        return "请输入要验证的IP地址!";
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Armitage是一个图形化的Metasploit界面,可以帮助渗透测试人员更加方便地使用Metasploit框架进行渗透测试。以下是使用Armitage进行渗透测试的步骤: 1. 安装Metasploit框架:Armitage需要Metasploit框架的支持,因此需要先安装Metasploit框架。具体安装方法可以参考Metasploit官方网站的文档。 2. 启动Armitage:在终端中输入armitage命令启动Armitage。 3. 连接Metasploit框架:在Armitage界面中,点击Connect按钮,输入Metasploit框架的主机地址、端口号、用户名和密码,点击Connect按钮连接Metasploit框架。 4. 扫描目标主机:在Armitage界面中,点击Hosts按钮,选择Nmap Scan按钮,输入目标主机的IP地址,选择需要扫描的端口号范围,点击Start Scan按钮开始扫描。 5. 选择攻击模块:在Armitage界面中,点击Modules按钮,选择需要使用的攻击模块。 6. 配置攻击选项:在Armitage界面中,配置攻击选项,例如目标主机的IP地址、端口号、漏洞等信息。 7. 发起攻击:在Armitage界面中,点击Attack按钮,发起攻击。 8. 控制远程主机:如果攻击成功,可以在Armitage界面中控制远程主机,例如获取系统信息、上传文件、执行命令等操作。 注意事项: 1. 在使用Armitage进行渗透测试时,需要遵守相关法律法规,不得进行非法的攻击行为。 2. 在使用Armitage进行渗透测试时,需要对目标主机进行事先的授权,不得未经授权进行渗透测试。 3. 在使用Armitage进行渗透测试时,需要对攻击进行充分的测试和验证,以避免对目标主机造成不必要的损失。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值