ホームページ バックエンド開発 PHPチュートリアル C# 検証コード生成プログラム_PHP チュートリアル

C# 検証コード生成プログラム_PHP チュートリアル

Jul 13, 2016 am 10:39 AM
aspnet ソフトウェアプログラミング

コード:

System の使用;
System.Data の使用;
System.Configuration の使用;
System.Collections の使用;
System.Web の使用;
System.Web.Security の使用;
System.Web.UI の使用;
System.Web の使用。 UI.WebControls;
System.Web.UI.WebControls.WebParts の使用;
System.Web.UI.HtmlControls の使用;
System.Drawing の使用;
パブリック部分クラス inc_ValidCode : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
VerifyCode v = new VerifyCode();
v.Length = 4;
v.FontSize = 14;
v.Chaos = true;
v.BackgroundColor = Color.White;
v.ChaosColor = Color.LightGray;
//v.CodeSerial = "0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f,g, h、i、j、k、l、m、n、o、p、q、r、s、t、u、v、w、x、y、z、A、B、C、D、E、F、 G、H、I、J、K、L、M、N、O、P、Q、R、S、T、U、V、W、X、Y、Z";
//v.Colors = this.colors;`````````````````````````````````````` '''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''' '''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''' ```````````````
//v.Fonts = this.fonts;
v.Padding = 2;
string code = v.CreateVerifyCode(); //取随机码
v.CreateImageOnPage(code, this.Context); // 出力画像
//Response.Cookies.Add(new HttpCookie("fcvalidtcode", code.ToUpper()));// Cookies を使用して取验证码的值
Session["bao_code"] = code.ToUpper() ;
}
public class VerifyCode
{
#region 验证码長度(默认6个验证码の長さ)#region 验证码長度(默认6个验证码の長さ)
int length = 6;
public int Length
{
get { 戻り長さ; }
set {長さ = 値; }
}
#endregion
#region 验证符号字体大小(曲効果を表示するため、40 画素を自行修正可能)#region 验证符号字体大(曲効果を表示するため、40 画素を自行修正可能)
t フォントサイズ= 30;
public int FontSize
{
get { return fontSize; }
set { fontSize = 値; }
}
#endregion
#region 边框补(默认1像素)#region 边框补(默认1像素)
int padding = 2;
public int Padding
{
get { return padding; }
set {パディング = 値; }
}
#endregion
#region 否か输出点(默认不输出)#region 否か输出点(默认不输出)
bool Chaos = true;
public bool Chaos
{
get { return Chaos; }
set {カオス = 値; }
}
#endregion
#region 出射点の颜色(默认 grey)#region 出射点の颜色(默认 grey)
Color ChaosColor = Color.LightGray;
public Color ChaosColor
{
get { return ChaosColor; }
set {chaosColor = 値; }
}
#endregion
#region 自定背景色(默认白色)#region 自定背景色(默认白色)
Color BackgroundColor = Color.White;
public Color BackgroundColor
{
get { return backgroundColor; }
set {backgroundColor = 値; }
}
#endregion
#region 自定义随机颜色数组#region 自定义随机颜色数组
Color[] Colors = { Color.Black, Color.Red, Color.DarkBlue, Color.Green, Color.Orange, Color. Brown、Color.DarkCyan、Color.Purple };
public Color[] Colors
{ www.jbxue.com
get { return Colors; }
set {色 = 値; }
}
#endregion
#region 自定义字体数组#region 自定义字体数组
string[] fonts = { "Arial", "Georgia" };
public string[] Fonts
{
get { return fonts; }
set { フォント = 値; }
}
#endregion
#region 自定义随机字文字列列(逗号分間隔)#region 自定义随机字文字列列(逗号分間隔)
string codeSerial = "0,1,2,3,4, 5,6,7,8,9,a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t, u、v、w、x、y、z、A、B、C、D、E、F、G、H、I、J、K、L、M、N、O、P、Q、R、S、 T,U,V,W,X,Y,Z";
public string CodeSerial
{
get { return codeSerial; }
set { codeSerial = 値; }
}
#endregion
#region 生成波形滤镜效果#region 生成波形滤镜效果
private const double PI = 3.1415926535897932384626433832795;
private const double PI2 = 6.2831 85307179586476925286766559;
/**/
///
/// 正弦波の歪んだ画像 (51aspx.com による編集)
///
/// 画像パス
/// < ;param name="bXDir">歪んでいる場合は True を選択してください
/// 波形の振幅倍数、振幅が大きいほど歪みの度合いが高くなります、通常は 3
/// 波形の開始位相、値の範囲は [0-2*PI)
/// public System.Drawing.Bitmap TwistImage(Bitmap srcBmp, bool bXDir, double dMultValue, double dPhase)
{
System.Drawing.Bitmap destBmp = new Bitmap(srcBmp.Width, srcBmp.Height);
// ビットマップ 背景を白で塗りつぶします
System.Drawing.Graphics chart = System.Drawing.Graphics.FromImage(destBmp);
graph.FillRectangle(new SolidBrush(System.Drawing.Color.White), 0, 0, destBmp.Width, destBmp.Height);
graph.Dispose();
double dBaseAxisLen = bXDir ? (double)destBmp.Height : (double)destBmp.Width;
for (int i = 0; i {
for (int j = 0; j double dx = 0;
dx = bXDir ? / dBaseAxisLen : (PI2 * (double)i) / dBaseAxisLen;
dx += dPhase;
double dy = Math.Sin(dx);
// 現在の点の色を取得します
int nOldX = 0, nOldY = 0 ;
nOldX = bXDir ? i + (int)(dy * dMultValue) : i;
nOldY = bXDir ? j : j + (int)(dy * dMultValue);
System.Drawing.Color color = srcBmp.GetPixel(i) , j);
if (nOldX >
}
#endregion
#region 検証コード画像を生成 #region 検証コード画像を生成
public Bitmap CreateImageCode(string code)
{
int fSize = FontSize;
int fWidth = fSize + Padding ;
int imageWidth = (int )(code.Length * fWidth) + 4 + Padding * 2;
int imageHeight = fSize * 2 + Padding;
System.Drawing.Bitmap image = new System.Drawing.Bitmap(imageWidth, imageHeight );
Graphics g = Graphics .FromImage(image);
g.Clear(BackgroundColor);
Random rand = new Random();
//ランダムに生成されたドライ ポイントを背景に追加します
if (this.Chaos)
{
ペンペン = new Pen(ChaosColor, 0);
int c = 長さ * 10;
for (int i = 0; i < c; i++)
{
int x = rand.Next(image.Width);
int y = rand.Next (image.Height);
g.DrawRectangle(pen, x, y, 1, 1);
}
}
int left = 0、top = 0、top1 = 1、top2 = 1 ;
int n1 = (imageHeight - FontSize - Padding * 2);
int n2 = n1 / 4;
top1 = n2;
top2 = n2 * 2;
フォント f;
ブラシ b;
int cindex, findex;
//ランダムなフォントと色の検証コード文字
for (int i = 0; i {
cindex = rand.Next(Colors.Length - 1);
findex = rand.Next(Fonts .Length - 1);
f = new System.Drawing.Font(Fonts[findex], fSize, System.Drawing.FontStyle.Bold);
b = new System.Drawing.SolidBrush(Colors[cindex]);
if (i % 2 == 1)
{
トップ = トップ 2;
}
else
{
トップ = トップ 1;
}
左 = i * fWidth;
g.DrawString(code.Substring(i, 1), f , b, left, top );
}
//Color.Gainsboroで境界線を描画します
g.DrawRectangle(new Pen(Color.Gainsboro, 0), 0, 0, image.Width - 1, image.Height - 1 );
g .Dispose();
//波形を生成 (51aspx.com で追加)
image = TwistImage(image, true, 0, 4);
return image;
}
#endregion
#region 作成した画像をページに出力 #region 作成した画像をページに出力
public void CreateImageOnPage(string code, HttpContext context)
{
System.IO.MemoryStream ms = new System.IO.MemoryStream () ;
ビットマップ画像 = this.CreateImageCode(code);
image.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg);
context.Response.ClearContent();
context.Response.ContentType = "image /Jpeg ";
context.Response.BinaryWrite(ms.GetBuffer());
ms.Close();
ms = null;
image.Dispose();
image = null;
}
#endregion
#region ランダムを生成文字コード #region ランダムな文字コードを生成します
public string CreateVerifyCode(int codeLen)
{
if (codeLen == 0)
{
codeLen = Length;
}
string[] arr = CodeSerial.Split(',' );
string code = "";
int randValue = -1;
Random rand = new Random(unchecked((int)DateTime.Now.Ticks)));
for (int i = 0; i {
randValue = rand.Next(0, arr.Length - 1);
code += arr[randValue];
}
return code;
}
public string CreateVerifyCode()
{
return CreateVerifyCode(0) ;
}
#endregion
}
}

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/729841.html技術記事コード: System.Data を使用; System.Web を使用; System.Web.UI を使用;
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Vue.js と ASP.NET の組み合わせは、Web アプリケーションのパフォーマンスの最適化と拡張のためのヒントと提案を提供します。 Vue.js と ASP.NET の組み合わせは、Web アプリケーションのパフォーマンスの最適化と拡張のためのヒントと提案を提供します。 Jul 29, 2023 pm 05:19 PM

Vue.js と ASP.NET の組み合わせは、Web アプリケーションのパフォーマンスの最適化と拡張のためのヒントと提案を提供します。Web アプリケーションの急速な開発に伴い、パフォーマンスの最適化は開発者にとって不可欠かつ重要なタスクになっています。人気のフロントエンド フレームワークとして、Vue.js を ASP.NET と組み合わせることで、より優れたパフォーマンスの最適化と拡張を実現できます。この記事では、いくつかのヒントと提案を紹介し、いくつかのコード例を示します。 1. HTTP リクエストの削減 HTTP リクエストの数は、Web アプリケーションの読み込み速度に直接影響します。合格

生成 AI がソフトウェア開発を変える 10 の方法 生成 AI がソフトウェア開発を変える 10 の方法 Mar 11, 2024 pm 12:10 PM

翻訳者 | Chen Jun によるレビュー | Chonglou 1990 年代、ソフトウェア プログラミングというと、通常、エディタを選択し、コードを CVS または SVN コード ベースにチェックインし、コードを実行可能ファイルにコンパイルすることを意味していました。 Eclipse や Visual Studio などの対応する統合開発環境 (IDE) は、プログラミング、開発、ドキュメント化、構築、テスト、展開、その他のステップを完全なソフトウェア開発ライフ サイクル (SDLC) に統合できるため、開発者の作業効率が向上します。近年、人気のクラウド コンピューティングと DevSecOps 自動化ツールにより、開発者の包括的な能力が向上し、より多くの企業がソフトウェア アプリケーションを開発、展開、保守することが容易になりました。今日、生成 AI は次世代の開発です

ASP.NET プログラムにおける MySQL 接続プールの使用法と最適化手法 ASP.NET プログラムにおける MySQL 接続プールの使用法と最適化手法 Jun 30, 2023 pm 11:54 PM

ASP.NET プログラムで MySQL 接続プールを正しく使用し、最適化するにはどうすればよいですか?はじめに: MySQL は、高いパフォーマンス、信頼性、使いやすさを特徴とする、広く使用されているデータベース管理システムです。 ASP.NET 開発では、データ ストレージに MySQL データベースを使用することが一般的な要件です。データベース接続の効率とパフォーマンスを向上させるには、MySQL 接続プールを正しく使用し、最適化する必要があります。この記事では、ASP.NET プログラムで MySQL 接続プールを正しく使用し、最適化する方法を紹介します。

ASP.NETプログラムでMySQLに再接続するにはどうすればよいですか? ASP.NETプログラムでMySQLに再接続するにはどうすればよいですか? Jun 29, 2023 pm 02:21 PM

ASP.NETプログラムでMySQLに再接続するにはどうすればよいですか? ASP.NET 開発では、MySQL データベースを使用するのが非常に一般的です。ただし、ネットワークまたはデータベース サーバーの理由により、データベース接続が中断されたりタイムアウトになったりする場合があります。この場合、プログラムの安定性と信頼性を確保するために、接続が切断された後に接続を再確立する必要があります。この記事では、ASP.NET プログラムで MySQL 接続を再接続する方法を紹介します。必要な名前空間を最初に参照するには、コード ファイルの先頭でそれらを参照します。

Vue.js と ASP.NET の組み合わせにより、エンタープライズ レベルのアプリケーションの開発と展開が可能になります。 Vue.js と ASP.NET の組み合わせにより、エンタープライズ レベルのアプリケーションの開発と展開が可能になります。 Jul 29, 2023 pm 02:37 PM

Vue.js と ASP.NET の組み合わせにより、エンタープライズ レベルのアプリケーションの開発と展開が可能になります。今日の急速に発展するインターネット テクノロジ分野では、エンタープライズ レベルのアプリケーションの開発と展開がますます重要になっています。 Vue.js と ASP.NET は、フロントエンドとバックエンドの開発で広く使用されている 2 つのテクノロジであり、これらを組み合わせることで、エンタープライズ レベルのアプリケーションの開発と展開に多くの利点をもたらします。この記事では、コード例を通じて、Vue.js と ASP.NET を使用してエンタープライズ レベルのアプリケーションを開発およびデプロイする方法を紹介します。まず、インストールする必要があります

ASP.NETプログラムでMySQL接続プールを正しく構成して使用する方法は? ASP.NETプログラムでMySQL接続プールを正しく構成して使用する方法は? Jun 29, 2023 pm 12:56 PM

ASP.NETプログラムでMySQL接続プールを正しく構成して使用する方法は?インターネットの発展とデータ量の増加に伴い、データベースへのアクセスと接続の需要も増加しています。データベースのパフォーマンスと安定性を向上させるために、接続プーリングは不可欠なテクノロジーになっています。この記事では、データベースの効率と応答速度を向上させるために、ASP.NET プログラムで MySQL 接続プールを正しく構成および使用する方法を主に紹介します。 1. コネクションプーリングの概念と機能 コネクションプーリングはデータベースコネクションを再利用する技術であり、プログラムの冒頭で使用されます。

ASP.NET での MySQL 接続プールのトランザクション パフォーマンスの使用と最適化 ASP.NET での MySQL 接続プールのトランザクション パフォーマンスの使用と最適化 Jun 30, 2023 pm 12:12 PM

ASP.NET プログラムで MySQL 接続プールのトランザクション パフォーマンスを正しく使用し、最適化するにはどうすればよいですか? ASP.NET プログラムでは、データベース トランザクションは非常に重要な部分です。トランザクションにより、データベースの一貫性と整合性が確保されると同時に、パフォーマンスも向上します。 MySQL データベースを使用する場合、接続リソースを管理し、パフォーマンスを最適化するために接続プールを使用することが不可欠です。まず、MySQL 接続プールの概念を簡単に理解しましょう。接続プールは、接続グループのバッファ プールです。

aspnet の組み込みオブジェクトとは何ですか? aspnet の組み込みオブジェクトとは何ですか? Nov 21, 2023 pm 02:59 PM

ASP.NET の組み込みオブジェクトには、「リクエスト」、「レスポンス」、「セッション」、「サーバー」、「アプリケーション」、 「HttpContext」、「Cache」、「Trace」、「Cookie」、および「Server.MapPath」: 1. リクエスト、クライアントによって発行された HTTP リクエストを示します; 2. レスポンス: Web サーバーによって返された HTTP 応答を示します。クライアントなど

See all articles