Vollendet "Überprüfung des AD-Passworts"Und"Änderung des AD-Passworts》Nach zwei APIs,Als nächstes verwenden Sie .NET MAUI Blazor, um Desktop-Programme zu schreiben。Nachdem ich ein wenig über Blazor erfahren habe,Ich fühle mich so magisch,Es fühlt sich an, als würde man eine Webseite in eine Anwendung einfügen,Während der Ausführung können Sie im „Job Manager“ auch Edge-bezogene Komponenten sehen, die dahinter ausgeführt werden.,Drücken Sie dann F12 und es erscheint ein Fenster mit den Entwicklertools! Aber das gab mir auch einige Sicherheitsbedenken.。Aber das Gesamtgefühl ist etwas ganz Besonderes.,Ich bin mit der Syntax von Webseiten vertraut,Verwenden Sie Razor, um UI-Bildschirme zu entwerfen,Fühlen Sie sich freundlicher。
Nach Fertigstellung API zur Überprüfung des AD-Passworts Nach Der,Versuchen Sie dann, den Teil zum Ändern des Passworts zu schreiben,Obwohl ich stolperte, habe ich es endlich geschafft.。Dieses Mal werde ich Ihnen zeigen, wie man drei verschiedene Pakete schreibt.,Und der Titel wird erwähnen “Ändern Sie Ihr AD-Passwort” Das liegt daran, dass ich es während des Schreibprozesses entdeckt habe,Für die Ausführung einiger Methoden sind die Berechtigungen eines Domänenadministrators erforderlich,Daher beschränkt sich der Umfang dieses Artikels auf die ausschließliche Verwendung des eigenen Kontos und Passworts des Benutzers.,Sie können die Aktion zum Ändern des Passworts abschließen。
Kürzlich habe ich versucht, ein Programm zur Änderung des AD-Kontokennworts über ASP.NET Core zu schreiben.,Was die Architektur betrifft, gibt es im Allgemeinen eine Web-API für die AD-Authentifizierung und Passwortänderung.,Schreiben Sie abschließend eine Desktop-Anwendung,Lassen Sie die Benutzer es selbst ändern。Was dieses Mal fertiggestellt ist, ist die Web-API zur Konto- und Passwortüberprüfung.,Das Programm ist wie folgt:
Zuvor berichteten Kollegen, dass die QR-Code-API von Google manchmal nicht funktionierte.,Nach Prüfung der relevanten Informationen,Ich hatte die Idee, C# durch das Schreiben dieser API zu lernen,Verbrachte einige Zeit mit der Erkundung,Ich habe es wirklich aus dir herausgeholt。Die Funktion dieser API besteht darin, einen Wert in die URL einzugeben,Sie können QRCode-Bilder direkt im Browser generieren,Im Folgenden wird zum ersten Mal ASP.NET Core geschrieben / Aus der Sicht eines C#-Neulings erklärt。
<%# Eval("SDate", "{0:yyyy/MM/dd}") %> // 0: 表示定義整個括號裡面的第 0 個變數要採用此日期格式。 // 以下為兩個變數的範例。 string s = String.Format("At {0}, the temperature is {1}°C.", DateTime.Now, 20.4); Console.WriteLine(s); // Output similar to: 'At 4/10/2015 9:29:41 AM, the temperature is 20.4°C.'
Referenz [link]
- asp.net – wie man ein bestimmtes FORMAT des Datums anwendet, indem man eval verwendet? – Paketüberfluss
- c # – Was bedeutet die 0 in “{0:MM TT JJJJ}” tun? – Paketüberfluss
- String.Format-Methode (System) | Microsoft Docs
- Benutzerdefinierte Formatzeichenfolgen für Datum und Uhrzeit | Microsoft Docs
- Standardformatzeichenfolgen für Datum und Uhrzeit | Microsoft Docs
//MVC3開始,新增Razer語法,不同於先前的<%...%>括號語法,使用At Sgin(@)敘述程式碼片段。 //在Razer檢視中,使用@*...*@進行程式註解。 //在程式碼中,要輸出內容,要加@或@(...) //在html標籤中,要輸出內容,要加@ //在程式碼中,要輸出純文字,要加@:
@if(true) { String strPrint = "這是測試輸出文字"; @strPrint<br/> <span>strPring</span><br /> <span>@strPrint</span><br /> } @{string strl = "測試";} @(strl)輸出文字<br /> @{ string strHtml1 = "<ul><li>項目一</li></ul>";} @Html.Raw(strHtml1)<br />
//在測試Controller與View時,如果因為設中斷點導致網頁顯示不完整而無法進行測試, //可以試著點選"跳離函式(Shift+F11)",讓頁面完整顯示,以進行測試。 //先於Model設計好欄位變數等, //再於Controller設定執行時,透過剛設計的Model樣板,進行各個變數的處理(遞交資料) //如從網頁欄位A讀取資料到變數X,再把X送到網頁的欄位B //最後於View設計各欄位的顯示情形
//Controllers\HomeController.cs public ActionResult Index() { TempData["Message"] = "修改此範本即可開始著手進行您的ASP.NET MVC應用程式。"; return View(); }
<!--Views\Home\Index.cshtml--> <h2>@TempData["Message"]</h2>
//資料模型一對多關聯 public class Guestbook { public int Id { get; set; } public string Content { get; set; } public DateTime CreateTime { get; set; } public Member Member { get; set; } } public class Member { [Key] public string Username { get; set; } public string Password { get; set; } public string Name { get; set; } public string Email { get; set; } public ICollection<Guestbook> Guestbook { get; set; } } //Code First 就是在Model定義好各欄位後,其他的Controller、View都會自動幫你產生, //很神奇的功能,讓你專注在寫Model的部分就好
public class Index { [DisplayName("必選修")] //上面中括號這項非必要 public string Required { get; set; } /*name只能有一個,所以這兩段先註解掉 [Required(ErrorMessage = "學生姓名不得為空白")] public string Name { get; set; } [StringLength(10, ErrorMessage = "學生姓名不得超過10字元")] public string Name { get; set; } */ [StringLength(10, ErrorMessage = "學生姓名必須介於2-10字元", MinimumLength = 2)] public string Name { get; set; } [Range(0, 100, ErrorMessage = "得分必須介於0~100之間")] public int Point { get; set; } [System.Web.Mvc.Compare("re_password", ErrorMessage = "兩次密碼輸入不一致")] //上面沒有using System.Web.Mvc的話,這邊就要打完整的命名空間 public string Password { get; set; } public string Re_password { get; set; } [RegularExpression( @"^[0-9]{2,4}-?[0-9]{3,4}-?[0-9]{-4}$", ErrorMessage = "請輸入正確的電話號碼")] public string Phone { get; set; } [EmailAddress(ErrorMessage = "這不是E-mail格式")] public string Studentmail { get; set; } [Url(ErrorMessage = "這不是網址標準格式")] public string Url { get; set; } [FileExtensions(ErrorMessage = "所上傳的檔案不是圖片")] public string File { get; set; } [CreditCard(ErrorMessage = "這不是信用卡格式")] public string CreditCard { get; set; } [DataType(DataType.Date)] public string Date { get; set; } [Remote("RemoteTest", "Home", ErrorMessage = "Remote屬性測試")] public string For_Remote { get; set; } [MetadataType(typeof(ContentMetaData))] public partial class Content { private class ContentMetaData { [DisplayName("編號")] public int Id { get; set; } [DisplayName("姓名")] [Required(ErrorMessage = "請輸入性名")] [StringLength(10, ErrorMessage = "姓名不得超過10字元")] public string Name { get; set; } [DisplayName("內容")] [Required(ErrorMessage = "請輸入內容")] public string Content { get; set; } } } }