diff --git a/net.nutcore.aliddns/net.nutcore.aliddns/Form_main.Designer.cs b/net.nutcore.aliddns/net.nutcore.aliddns/Form_main.Designer.cs
index cff8a35..2ac8be2 100644
--- a/net.nutcore.aliddns/net.nutcore.aliddns/Form_main.Designer.cs
+++ b/net.nutcore.aliddns/net.nutcore.aliddns/Form_main.Designer.cs
@@ -85,6 +85,8 @@
this.comboBox_whatIsUrl = new System.Windows.Forms.ComboBox();
this.button_whatIsTest = new System.Windows.Forms.Button();
this.label14 = new System.Windows.Forms.Label();
+ this.button_addNewDomain = new System.Windows.Forms.Button();
+ this.button_addUrl = new System.Windows.Forms.Button();
this.timeSetGroup.SuspendLayout();
this.debugMessage.SuspendLayout();
this.globalSetGroup.SuspendLayout();
@@ -219,7 +221,7 @@
this.debugMessage.Controls.Add(this.label9);
this.debugMessage.Location = new System.Drawing.Point(219, 47);
this.debugMessage.Name = "debugMessage";
- this.debugMessage.Size = new System.Drawing.Size(206, 79);
+ this.debugMessage.Size = new System.Drawing.Size(216, 79);
this.debugMessage.TabIndex = 5;
this.debugMessage.TabStop = false;
this.debugMessage.Text = "调试信息";
@@ -317,6 +319,7 @@
//
// globalSetGroup
//
+ this.globalSetGroup.Controls.Add(this.button_addNewDomain);
this.globalSetGroup.Controls.Add(this.label13);
this.globalSetGroup.Controls.Add(this.textBox_TTL);
this.globalSetGroup.Controls.Add(this.button_ShowHide);
@@ -332,7 +335,7 @@
this.globalSetGroup.Controls.Add(this.label4);
this.globalSetGroup.Location = new System.Drawing.Point(219, 132);
this.globalSetGroup.Name = "globalSetGroup";
- this.globalSetGroup.Size = new System.Drawing.Size(206, 198);
+ this.globalSetGroup.Size = new System.Drawing.Size(216, 198);
this.globalSetGroup.TabIndex = 6;
this.globalSetGroup.TabStop = false;
this.globalSetGroup.Text = "设置";
@@ -340,7 +343,7 @@
// label13
//
this.label13.AutoSize = true;
- this.label13.Location = new System.Drawing.Point(8, 124);
+ this.label13.Location = new System.Drawing.Point(8, 123);
this.label13.Margin = new System.Windows.Forms.Padding(2, 0, 2, 0);
this.label13.Name = "label13";
this.label13.Size = new System.Drawing.Size(47, 12);
@@ -349,7 +352,7 @@
//
// textBox_TTL
//
- this.textBox_TTL.Location = new System.Drawing.Point(65, 121);
+ this.textBox_TTL.Location = new System.Drawing.Point(65, 120);
this.textBox_TTL.Margin = new System.Windows.Forms.Padding(2);
this.textBox_TTL.Name = "textBox_TTL";
this.textBox_TTL.Size = new System.Drawing.Size(37, 21);
@@ -359,9 +362,9 @@
//
// button_ShowHide
//
- this.button_ShowHide.Location = new System.Drawing.Point(106, 169);
+ this.button_ShowHide.Location = new System.Drawing.Point(75, 169);
this.button_ShowHide.Name = "button_ShowHide";
- this.button_ShowHide.Size = new System.Drawing.Size(91, 23);
+ this.button_ShowHide.Size = new System.Drawing.Size(65, 23);
this.button_ShowHide.TabIndex = 14;
this.button_ShowHide.Text = "显示录入";
this.button_ShowHide.UseVisualStyleBackColor = true;
@@ -369,9 +372,9 @@
//
// checkAndSaveConfig
//
- this.checkAndSaveConfig.Location = new System.Drawing.Point(8, 169);
+ this.checkAndSaveConfig.Location = new System.Drawing.Point(5, 169);
this.checkAndSaveConfig.Name = "checkAndSaveConfig";
- this.checkAndSaveConfig.Size = new System.Drawing.Size(93, 23);
+ this.checkAndSaveConfig.Size = new System.Drawing.Size(65, 23);
this.checkAndSaveConfig.TabIndex = 10;
this.checkAndSaveConfig.Text = "测试连接";
this.checkAndSaveConfig.UseVisualStyleBackColor = true;
@@ -380,7 +383,7 @@
// label8
//
this.label8.AutoSize = true;
- this.label8.Location = new System.Drawing.Point(107, 152);
+ this.label8.Location = new System.Drawing.Point(107, 148);
this.label8.Name = "label8";
this.label8.Size = new System.Drawing.Size(65, 12);
this.label8.TabIndex = 8;
@@ -388,7 +391,7 @@
//
// newSeconds
//
- this.newSeconds.Location = new System.Drawing.Point(41, 149);
+ this.newSeconds.Location = new System.Drawing.Point(41, 145);
this.newSeconds.Name = "newSeconds";
this.newSeconds.Size = new System.Drawing.Size(60, 21);
this.newSeconds.TabIndex = 7;
@@ -398,7 +401,7 @@
// label7
//
this.label7.AutoSize = true;
- this.label7.Location = new System.Drawing.Point(6, 152);
+ this.label7.Location = new System.Drawing.Point(6, 148);
this.label7.Name = "label7";
this.label7.Size = new System.Drawing.Size(29, 12);
this.label7.TabIndex = 6;
@@ -489,7 +492,7 @@
this.toolStripMenuItem_Exit.Name = "toolStripMenuItem_Exit";
this.toolStripMenuItem_Exit.Size = new System.Drawing.Size(124, 22);
this.toolStripMenuItem_Exit.Text = "退出";
- this.toolStripMenuItem_Exit.Click += new System.EventHandler(this.toolStripMenuItem1_Click);
+ this.toolStripMenuItem_Exit.Click += new System.EventHandler(this.toolStripMenuItem_Quit_Click);
//
// ToolStripMenuItem_checkUpdate
//
@@ -512,7 +515,7 @@
this.textBox_log.Name = "textBox_log";
this.textBox_log.ReadOnly = true;
this.textBox_log.ScrollBars = System.Windows.Forms.ScrollBars.Both;
- this.textBox_log.Size = new System.Drawing.Size(413, 109);
+ this.textBox_log.Size = new System.Drawing.Size(423, 109);
this.textBox_log.TabIndex = 8;
//
// groupBox_netstate
@@ -525,7 +528,7 @@
this.groupBox_netstate.Controls.Add(this.label1);
this.groupBox_netstate.Location = new System.Drawing.Point(12, 3);
this.groupBox_netstate.Name = "groupBox_netstate";
- this.groupBox_netstate.Size = new System.Drawing.Size(413, 38);
+ this.groupBox_netstate.Size = new System.Drawing.Size(423, 38);
this.groupBox_netstate.TabIndex = 9;
this.groupBox_netstate.TabStop = false;
this.groupBox_netstate.Text = "网络状态";
@@ -534,7 +537,7 @@
//
this.label_DomainIpStatus.AutoSize = true;
this.label_DomainIpStatus.ForeColor = System.Drawing.Color.Red;
- this.label_DomainIpStatus.Location = new System.Drawing.Point(364, 19);
+ this.label_DomainIpStatus.Location = new System.Drawing.Point(371, 19);
this.label_DomainIpStatus.Name = "label_DomainIpStatus";
this.label_DomainIpStatus.Size = new System.Drawing.Size(41, 12);
this.label_DomainIpStatus.TabIndex = 9;
@@ -553,7 +556,7 @@
// domainIP
//
this.domainIP.AutoSize = true;
- this.domainIP.Location = new System.Drawing.Point(259, 19);
+ this.domainIP.Location = new System.Drawing.Point(264, 19);
this.domainIP.Name = "domainIP";
this.domainIP.Size = new System.Drawing.Size(47, 12);
this.domainIP.TabIndex = 7;
@@ -562,7 +565,7 @@
// label2
//
this.label2.AutoSize = true;
- this.label2.Location = new System.Drawing.Point(213, 19);
+ this.label2.Location = new System.Drawing.Point(218, 19);
this.label2.Name = "label2";
this.label2.Size = new System.Drawing.Size(47, 12);
this.label2.TabIndex = 6;
@@ -588,6 +591,7 @@
//
// groupBox_setWanIp
//
+ this.groupBox_setWanIp.Controls.Add(this.button_addUrl);
this.groupBox_setWanIp.Controls.Add(this.maskedTextBox_setIP);
this.groupBox_setWanIp.Controls.Add(this.button_setIP);
this.groupBox_setWanIp.Controls.Add(this.comboBox_whatIsUrl);
@@ -636,7 +640,7 @@
//
this.button_whatIsTest.Location = new System.Drawing.Point(6, 66);
this.button_whatIsTest.Name = "button_whatIsTest";
- this.button_whatIsTest.Size = new System.Drawing.Size(189, 23);
+ this.button_whatIsTest.Size = new System.Drawing.Size(90, 23);
this.button_whatIsTest.TabIndex = 17;
this.button_whatIsTest.Text = "获取WAN口IP";
this.button_whatIsTest.UseVisualStyleBackColor = true;
@@ -651,11 +655,31 @@
this.label14.TabIndex = 16;
this.label14.Text = "查询网址:";
//
+ // button_addNewDomain
+ //
+ this.button_addNewDomain.Location = new System.Drawing.Point(145, 169);
+ this.button_addNewDomain.Name = "button_addNewDomain";
+ this.button_addNewDomain.Size = new System.Drawing.Size(65, 23);
+ this.button_addNewDomain.TabIndex = 17;
+ this.button_addNewDomain.Text = "添加域名";
+ this.button_addNewDomain.UseVisualStyleBackColor = true;
+ this.button_addNewDomain.Click += new System.EventHandler(this.button_addNewDomain_Click);
+ //
+ // button_addUrl
+ //
+ this.button_addUrl.Location = new System.Drawing.Point(105, 66);
+ this.button_addUrl.Name = "button_addUrl";
+ this.button_addUrl.Size = new System.Drawing.Size(90, 23);
+ this.button_addUrl.TabIndex = 21;
+ this.button_addUrl.Text = "添加地址";
+ this.button_addUrl.UseVisualStyleBackColor = true;
+ this.button_addUrl.Click += new System.EventHandler(this.button_addUrl_Click);
+ //
// mainForm
//
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 12F);
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
- this.ClientSize = new System.Drawing.Size(437, 451);
+ this.ClientSize = new System.Drawing.Size(447, 451);
this.Controls.Add(this.groupBox_setWanIp);
this.Controls.Add(this.groupBox_netstate);
this.Controls.Add(this.textBox_log);
@@ -741,6 +765,8 @@
private System.Windows.Forms.Button button_ngrok;
private System.Windows.Forms.CheckBox checkBox_ngrok;
public System.Windows.Forms.TextBox textBox_log;
+ private System.Windows.Forms.Button button_addNewDomain;
+ private System.Windows.Forms.Button button_addUrl;
}
}
diff --git a/net.nutcore.aliddns/net.nutcore.aliddns/Form_main.cs b/net.nutcore.aliddns/net.nutcore.aliddns/Form_main.cs
index 328c690..4ce9b5a 100644
--- a/net.nutcore.aliddns/net.nutcore.aliddns/Form_main.cs
+++ b/net.nutcore.aliddns/net.nutcore.aliddns/Form_main.cs
@@ -29,6 +29,11 @@ namespace net.nutcore.aliddns
this.MaximizeBox = false; //取消窗口最大化按钮
}
+ ///
+ /// mainForm窗体加载
+ ///
+ ///
+ ///
private void mainForm_Load(object sender, EventArgs e)
{
//获取当前用户名和计算机名并写入日志
@@ -100,36 +105,22 @@ namespace net.nutcore.aliddns
this.ShowInTaskbar = true; //从状态栏显示
}
- try //获取域名绑定IP
- {
- clientProfile = DefaultProfile.GetProfile("cn-hangzhou", accessKeyId.Text, accessKeySecret.Text);
- client = new DefaultAcsClient(clientProfile);
- domainIP.Text = getDomainIP();
- }
- catch (Exception error)
- {
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "运行出错!信息: " + error + "\r\n");
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "获取域名和绑定IP失败,请检查设置项目内容和网络状态!" + "\r\n");
- }
- }
-
- try //获取WAN口IP
- {
- localIP.Text = getLocalIP();
+ //获取阿里云域名记录绑定IP
+ domainIP.Text = getAliDnsRecordDomainIP();
+ //获取WAN口IP
+ localIP.Text = getWanIP();
if ((localIP.Text != domainIP.Text) && (checkBox_autoBoot.Checked = true))
{
updatePrepare();
}
}
- catch (Exception error)
- {
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "运行出错!信息: " + error + "\r\n");
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "获取WAN口IP失败!" + "\r\n");
- }
-
notifyIcon_sysTray_Update(); //监测网络状态、刷新系统托盘图标
}
+ ///
+ /// 读取配置文件并初始化控件
+ ///
+ ///
private bool readConfigFile()
{
try
@@ -178,16 +169,23 @@ namespace net.nutcore.aliddns
}
- private string getLocalIP()
+ ///
+ /// 获取网络出口公网IP
+ ///
+ ///
+ private string getWanIP()
{
try
{
- string strUrl = comboBox_whatIsUrl.Text; //从控件获取WAN口IP查询网址,默认值为:"http://whatismyip.akamai.com/";
+ //从控件获取WAN口IP查询网址,默认值为:"http://whatismyip.akamai.com/";
+ string strUrl = comboBox_whatIsUrl.Text;
Uri uri = new Uri(strUrl);
WebRequest webreq = WebRequest.Create(uri);
Stream s = webreq.GetResponse().GetResponseStream();
StreamReader sr = new StreamReader(s, Encoding.Default);
string all = sr.ReadToEnd();
+ sr.Close();
+ sr.Dispose();
all = Regex.Replace(all, @"(\d+)", "000$1");
all = Regex.Replace(all, @"0+(\d{1,4})", "$1");
string reg = @"(\d{1,4}\.\d{1,4}\.\d{1,4}\.\d{1,4})";
@@ -213,39 +211,43 @@ namespace net.nutcore.aliddns
}
}
- private bool setRecordId() //获取阿里云解析返回recordId
+ ///
+ /// 从阿里云获取域名记录
+ ///
+ ///
+ private bool getRecordId() //获取阿里云解析返回recordId
{
+ clientProfile = DefaultProfile.GetProfile("cn-hangzhou", accessKeyId.Text.ToString(), accessKeySecret.Text.ToString());
+ client = new DefaultAcsClient(clientProfile);
DescribeSubDomainRecordsRequest request = new DescribeSubDomainRecordsRequest();
request.SubDomain = fullDomainName.Text;
try
- {
+ {
DescribeSubDomainRecordsResponse response = client.GetAcsResponse(request);
List list = response.DomainRecords;
if (list.Count == 0) //当不存在域名记录时,添加一个
{
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "阿里云DNS服务访问成功,但没有找到对应域名信息!" + "\r\n");
- if (addDomainRecord())
- return true;
- else
- return false;
+ textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "阿里云DNS服务访问成功,但没有找到对应域名记录,请添加域名后重试!" + "\r\n");
+ return false;
}
-
- int i = 0;
-
- foreach (Record record in list) //当存在域名记录时,返回域名记录信息
+ else
{
- i++;
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "阿里云DNS服务返回RecordId:" + i.ToString() + " RecordId:" + record.RecordId + "\r\n");
- recordId.Text = record.RecordId;
- globalRR.Text = record.RR;
- globalDomainType.Text = record.Type;
- globalValue.Text = domainIP.Text = record.Value;
- label_TTL.Text = Convert.ToString(record.TTL);
- label_DomainIpStatus.Text = "已绑定";
- label_DomainIpStatus.ForeColor = System.Drawing.Color.FromArgb(0, 0, 0, 255);
+ int i = 0;
+ foreach (Record record in list) //当存在域名记录时,返回域名记录信息
+ {
+ i++;
+ textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "阿里云DNS服务返回RecordId:" + i.ToString() + " RecordId:" + record.RecordId + "\r\n");
+ recordId.Text = record.RecordId;
+ globalRR.Text = record.RR;
+ globalDomainType.Text = record.Type;
+ globalValue.Text = domainIP.Text = record.Value;
+ label_TTL.Text = Convert.ToString(record.TTL);
+ label_DomainIpStatus.Text = "已绑定";
+ label_DomainIpStatus.ForeColor = System.Drawing.Color.FromArgb(0, 0, 0, 255);
+ }
+ return true;
}
- return true;
}
//处理错误
catch (ServerException e)
@@ -260,15 +262,30 @@ namespace net.nutcore.aliddns
}
}
- private string getDomainIP()
+ ///
+ /// 从阿里云服务器获取域名记录信息
+ ///
+ ///
+ private string getAliDnsRecordDomainIP()
{
+ clientProfile = DefaultProfile.GetProfile("cn-hangzhou", accessKeyId.Text.ToString(), accessKeySecret.Text.ToString());
+ client = new DefaultAcsClient(clientProfile);
DescribeDomainRecordInfoRequest request = new DescribeDomainRecordInfoRequest();
- request.RecordId = recordId.Text;
+ request.RecordId = recordId.Text.ToString();
try
{
DescribeDomainRecordInfoResponse response = client.GetAcsResponse(request);
+ string fullDomain = response.RR.ToString() + "." + response.DomainName.ToString();
if (response.Value != "0.0.0.0")
{
+ if(fullDomain != fullDomainName.Text.ToString())
+ {
+ textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "阿里云DNS域名记录:"+ response.RecordId + " 对应域名为:" + fullDomain + "\r\n");
+ textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "配置文件域名记录:" + recordId.Text.ToString() + " 对应域名为:" + fullDomainName.Text.ToString() + "\r\n");
+ textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "配置文件设置错误!可能原因是修改域名记录后未及时添加,已经自动修改配置文件与服务器记录一致!" + "\r\n");
+ fullDomainName.Text = fullDomain;
+ cfg.SaveAppSetting("fullDomainName", fullDomain);
+ }
textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "域名:" + response.RR + "." + response.DomainName + " 已经绑定IP:" + response.Value + "\r\n");
recordId.Text = response.RecordId;
globalRR.Text = response.RR;
@@ -299,6 +316,9 @@ namespace net.nutcore.aliddns
}
}
+ ///
+ /// 更新域名记录
+ ///
private void updateDomainRecord()
{
string[] symbols = new string[1] { "." };
@@ -306,6 +326,8 @@ namespace net.nutcore.aliddns
string domainRR = data[0];
string domainName = data[1] + "." + data[2];
+ clientProfile = DefaultProfile.GetProfile("cn-hangzhou", accessKeyId.Text.ToString(), accessKeySecret.Text.ToString());
+ client = new DefaultAcsClient(clientProfile);
UpdateDomainRecordRequest request = new UpdateDomainRecordRequest();
request.Type = "A";
request.RR = domainRR;
@@ -334,6 +356,10 @@ namespace net.nutcore.aliddns
}
}
+ ///
+ /// 添加域名记录
+ ///
+ ///
private bool addDomainRecord()
{
string[] symbols = new string[1] { "." };
@@ -341,6 +367,8 @@ namespace net.nutcore.aliddns
string domainRR = data[0];
string domainName = data[1] + "." + data[2];
+ clientProfile = DefaultProfile.GetProfile("cn-hangzhou", accessKeyId.Text.ToString(), accessKeySecret.Text.ToString());
+ client = new DefaultAcsClient(clientProfile);
AddDomainRecordRequest request = new AddDomainRecordRequest();
request.Type = "A";
request.RR = domainRR;
@@ -352,14 +380,30 @@ namespace net.nutcore.aliddns
textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "正在向阿里云DNS服务添加域名:" + fullDomainName.Text + "\r\n");
AddDomainRecordResponse response = client.GetAcsResponse(request);
if (response.RecordId != null)
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "RecordId:" + response.RecordId + " 域名:" + fullDomainName.Text + "添加成功!" + "\r\n");
- recordId.Text = response.RecordId;
- globalDomainType.Text = request.Type;
- globalRR.Text = request.RR;
- globalValue.Text = domainIP.Text = request.Value;
- label_DomainIpStatus.Text = "已绑定";
- label_DomainIpStatus.ForeColor = System.Drawing.Color.FromArgb(0, 0, 0, 255);
- return true;
+ {
+ textBox_log.AppendText(System.DateTime.Now.ToString() + " " + " 域名:" + fullDomainName.Text + "添加成功!" + "服务器返回RecordId:" + response.RecordId + "\r\n");
+ recordId.Text = response.RecordId;
+ globalDomainType.Text = request.Type;
+ globalRR.Text = request.RR;
+ globalValue.Text = domainIP.Text = request.Value;
+ label_DomainIpStatus.Text = "已绑定";
+ label_DomainIpStatus.ForeColor = System.Drawing.Color.FromArgb(0, 0, 0, 255);
+ return true;
+ }
+ else
+ {
+ textBox_log.AppendText(System.DateTime.Now.ToString() + " " + " 域名:" + fullDomainName.Text + "添加失败!" + "\r\n");
+ label_DomainIpStatus.Text = "未绑定";
+ domainIP.Text = "0.0.0.0";
+ recordId.Text = "null";
+ globalRR.Text = "null";
+ globalDomainType.Text = "null";
+ globalValue.Text = "null";
+ label_TTL.Text = "null";
+ label_DomainIpStatus.ForeColor = System.Drawing.Color.FromArgb(255, 255, 0, 0);
+ return false;
+ }
+
}
//处理错误
catch (ServerException e)
@@ -374,34 +418,29 @@ namespace net.nutcore.aliddns
}
}
+ ///
+ /// 比较是否需要更新域名信息
+ ///
private void updatePrepare()
{
label_nextUpdateSeconds.Text = newSeconds.Text;
- try
+ localIP.Text = getWanIP();
+ domainIP.Text = getAliDnsRecordDomainIP();
+ if (domainIP.Text == localIP.Text)
{
- localIP.Text = getLocalIP();
- domainIP.Text = getDomainIP();
- if (domainIP.Text == localIP.Text)
- {
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "WAN口IP:" + localIP.Text + " 与域名绑定IP:" + domainIP.Text + "一致,无需更新!" + "\r\n");
- }
- else
- {
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "WAN口IP:" + localIP.Text + " 与域名绑定IP:" + domainIP.Text + "不一致,需要更新!" + "\r\n");
- updateDomainRecord();
- }
- //localIP.Text = getLocalIP();
- //domainIP.Text = getDomainIP();
+ textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "WAN口IP:" + localIP.Text + " 与域名绑定IP:" + domainIP.Text + "一致,无需更新!" + "\r\n");
}
- catch (Exception error)
+ else
{
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "运行出错!信息: " + error + "\r\n");
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "域名绑定IP更新失败!" + "\r\n");
+ textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "WAN口IP:" + localIP.Text + " 与域名绑定IP:" + domainIP.Text + "不一致,需要更新!" + "\r\n");
+ updateDomainRecord();
}
- notifyIcon_sysTray_Update(); //监测网络状态、刷新系统托盘图标
+ //localIP.Text = getWanIP();
+ //domainIP.Text = getAliDnsRecordDomainIP();
+ //监测网络状态、刷新系统托盘图标
+ notifyIcon_sysTray_Update();
}
- //Events in form
private void updateNow_Click(object sender, EventArgs e)
{
textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "---立即开始WAN口IP和域名绑定IP进行查询比较---" + "\r\n");
@@ -410,33 +449,13 @@ namespace net.nutcore.aliddns
private void checkConfig_Click(object sender, EventArgs e)
{
- try
+ if (getRecordId())
{
- //localIP.Text = getLocalIP(); //读取WAN口IP
- //domainIP.Text = getDomainIP(); //读取AliDDNS已经绑定IP
- clientProfile = DefaultProfile.GetProfile("cn-hangzhou", accessKeyId.Text, accessKeySecret.Text);
- client = new DefaultAcsClient(clientProfile);
- if (setRecordId()) //检查能否从服务器返回RecordId,返回则设置正确,否则设置不正确
- {
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "阿里云DNS服务返回RecordId,连接成功! " + "\r\n");
- }
- else
- {
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "阿里云DNS服务没有返回RecordId,请检查设置项目是否正确!" + "\r\n");
- }
+ textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "测试结果->成功!" + "\r\n");
}
- catch (Exception error)
+ else
{
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "运行出错!信息: " + error + "\r\n");
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "阿里云DNS服务访问失败,请检查账户accessKeyId和accessKeySecret!" + "\r\n");
- label_DomainIpStatus.Text = "未绑定";
- domainIP.Text = "0.0.0.0";
- recordId.Text = "null";
- globalRR.Text = "null";
- globalDomainType.Text = "null";
- globalValue.Text = "null";
- label_TTL.Text = "null";
- label_DomainIpStatus.ForeColor = System.Drawing.Color.FromArgb(255, 255, 0, 0);
+ textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "测试结果->失败!请检查设置项目是否正确!" + "\r\n");
}
notifyIcon_sysTray_Update(); //监测网络状态、刷新系统托盘图标
}
@@ -463,8 +482,9 @@ namespace net.nutcore.aliddns
}
}
- private void toolStripMenuItem1_Click(object sender, EventArgs e)
+ private async void toolStripMenuItem_Quit_Click(object sender, EventArgs e)
{
+ await ngrok.Stop();
this.Dispose();
}
@@ -494,7 +514,7 @@ namespace net.nutcore.aliddns
private void button_whatIsTest_Click(object sender, EventArgs e)
{
textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "开始向网址发起查询... " + "\r\n");
- localIP.Text = getLocalIP();
+ localIP.Text = getWanIP();
notifyIcon_sysTray_Update(); //监测网络状态、刷新系统托盘图标
}
@@ -644,7 +664,8 @@ namespace net.nutcore.aliddns
{
textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "运行出错!信息: " + error + "\r\n");
}
- notifyIcon_sysTray_Update(); //监测网络状态、刷新系统托盘图标
+ //监测网络状态、刷新系统托盘图标
+ notifyIcon_sysTray_Update();
}
private void notifyIcon_sysTray_Update()
@@ -738,7 +759,7 @@ namespace net.nutcore.aliddns
//检测ngrok.exe是否存在
if (ngrok.IsExists())
{
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "Ngrok功能启用,ngrok.exe将自动加载!通过浏览器打开:http://127.0.0.1:4040 查看运行状态。" + "\r\n");
+ textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "Ngrok功能启用,ngrok.exe将自动加载!本机浏览器打开:http://127.0.0.1:4040 查看运行状态。" + "\r\n");
await ngrok.Start();
}
else
@@ -766,50 +787,26 @@ namespace net.nutcore.aliddns
//检测ngrok.exe是否存在
if (( checkBox_ngrok.Checked == true ) && ( !ngrok.IsExists() ))
{
- MessageBox.Show("设置在当前目录没有发现ngrok.exe,请往官网下载自行编译。\nNgrok官网:https://ngrok.com/download");
+ MessageBox.Show("软件运行目录没有发现ngrok.exe,请往官网下载自行编译。\nNgrok官网:https://ngrok.com/download");
}
}
private void fullDomainName_Leave(object sender, EventArgs e)
{
- DialogResult result = MessageBox.Show("请确认域名: " + this.fullDomainName.Text.ToString(), "提醒", MessageBoxButtons.YesNo);
- if (result == DialogResult.Yes)
- {
- cfg.SaveAppSetting("fullDomainName", this.fullDomainName.Text.ToString());
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "域名已经保存,点击测试连接将测试创建域名记录!" + "\r\n");
- }
- else
- {
- this.fullDomainName.Focus();
- }
+ cfg.SaveAppSetting("fullDomainName", this.fullDomainName.Text.ToString());
+ textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "域名已经保存,点击测试连接将查询域名是否存在,当不存在时点击添加域名会创建新域名记录!" + "\r\n");
}
private void accessKeyId_Leave(object sender, EventArgs e)
{
- DialogResult result = MessageBox.Show("请确认accessKeyId:\n" + this.accessKeyId.Text.ToString(), "提醒", MessageBoxButtons.YesNo);
- if (result == DialogResult.Yes)
- {
- cfg.SaveAppSetting("AccessKeyID", EncryptHelper.AESEncrypt(this.accessKeyId.Text.ToString()));
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "accessKeyId已经保存,请完成设置录入后点击测试连接!" + "\r\n");
- }
- else
- {
- this.accessKeyId.Focus();
- }
+ cfg.SaveAppSetting("AccessKeyID", EncryptHelper.AESEncrypt(this.accessKeyId.Text.ToString()));
+ textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "accessKeyId已经保存,请完成设置录入后点击测试连接!" + "\r\n");
}
private void accessKeySecret_Leave(object sender, EventArgs e)
{
- DialogResult result = MessageBox.Show("请确认accessKeySecret:\n" + this.accessKeySecret.Text.ToString(), "提醒", MessageBoxButtons.YesNo);
- if (result == DialogResult.Yes)
- {
- cfg.SaveAppSetting("AccessKeySecret", EncryptHelper.AESEncrypt(this.accessKeySecret.Text.ToString()));
- textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "accessKeySecret已经保存,请完成设置录入后点击测试连接!" + "\r\n");
- }
- else
- {
- this.accessKeySecret.Focus();
- }
+ cfg.SaveAppSetting("AccessKeySecret", EncryptHelper.AESEncrypt(this.accessKeySecret.Text.ToString()));
+ textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "accessKeySecret已经保存,请完成设置录入后点击测试连接!" + "\r\n");
}
private void textBox_TTL_Leave(object sender, EventArgs e)
@@ -829,5 +826,17 @@ namespace net.nutcore.aliddns
cfg.SaveAppSetting("whatIsUrl", this.comboBox_whatIsUrl.Text.ToString());
textBox_log.AppendText(System.DateTime.Now.ToString() + " " + "公网IP查询网址修改保存成功!" + "\r\n");
}
+
+ private void button_addNewDomain_Click(object sender, EventArgs e)
+ {
+ addDomainRecord();
+ }
+
+ private void button_addUrl_Click(object sender, EventArgs e)
+ {
+ string newItem = comboBox_whatIsUrl.Text.Trim().ToLower().ToString();
+ comboBox_whatIsUrl.Items.Add(newItem);
+ cfg.AddAppSetting("whatIsUrl", newItem);
+ }
}
}