activity_main.xml
布局代码:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="${relativePackage}.${activityClass}" > <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:layout_marginLeft="10dp" android:orientation="vertical"> <ImageView android:id="@+id/image" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="10dp" android:src="@drawable/ic_launcher"/> <EditText android:id="@+id/et" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="10dp" android:hint="输入验证码"/> <Button android:id="@+id/btn" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="10dp" android:text="获得验证码"/> <Button android:id="@+id/btn_submit" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="10dp" android:text="提交"/> </LinearLayout> </RelativeLayout>
mainactivity代码:
package com.example.codedemo; import android.app.Activity; import android.graphics.Bitmap; import android.os.Bundle; import android.text.TextUtils; import android.util.Log; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.EditText; import android.widget.ImageView; import android.widget.Toast; public class MainActivity extends Activity implements OnClickListener { private ImageView image; private EditText et; private Button btn,submit; private String codeStr; private CodeUtils codeUtils; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); } private void initView() { image = (ImageView) findViewById(R.id.image); et = (EditText) findViewById(R.id.et); btn = (Button) findViewById(R.id.btn); submit = (Button) findViewById(R.id.btn_submit); btn.setOnClickListener(this); submit.setOnClickListener(this); } @Override public void onClick(View v) { switch (v.getId()) { case R.id.btn: codeUtils = CodeUtils.getInstance(); Bitmap bitmap = codeUtils.createBitmap(); image.setImageBitmap(bitmap); break; case R.id.btn_submit: codeStr = et.getText().toString().trim(); Log.e("codeStr", codeStr); if (null == codeStr || TextUtils.isEmpty(codeStr)) { Toast.makeText(this, "请输入验证码", 0).show(); return; } String code = codeUtils.getCode(); Log.e("code", code); if (code.equalsIgnoreCase(codeStr)) { Toast.makeText(this, "验证码正确", 0).show(); } else { Toast.makeText(this, "验证码错误", 0).show(); } break; default: break; } } }
最后附上CodeUtils代码:
package com.example.codedemo; import android.graphics.Bitmap; import android.graphics.Bitmap.Config; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import java.util.Random; /** * Created by yao * 用于图片验证码的工具类 */ public class CodeUtils { private static final char[] CHARS = { '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' }; private static CodeUtils mCodeUtils; private int mPaddingLeft, mPaddingTop; private StringBuilder mBuilder = new StringBuilder(); private Random mRandom = new Random(); //Default Settings private static final int DEFAULT_CODE_LENGTH = 6;//验证码的长度 这里是6位 private static final int DEFAULT_FONT_SIZE = 60;//字体大小 private static final int DEFAULT_LINE_NUMBER = 3;//多少条干扰线 private static final int BASE_PADDING_LEFT = 20; //左边距 private static final int RANGE_PADDING_LEFT = 30;//左边距范围值 private static final int BASE_PADDING_TOP = 70;//上边距 private static final int RANGE_PADDING_TOP = 15;//上边距范围值 private static final int DEFAULT_WIDTH = 300;//默认宽度.图片的总宽 private static final int DEFAULT_HEIGHT = 100;//默认高度.图片的总高 private static final int DEFAULT_COLOR = 0xDF;//默认背景颜色值 private String code; public static CodeUtils getInstance() { if(mCodeUtils == null) { mCodeUtils = new CodeUtils(); } return mCodeUtils; } //生成验证码图片 public Bitmap createBitmap() { mPaddingLeft = 0; //每次生成验证码图片时初始化 mPaddingTop = 0; Bitmap bitmap = Bitmap.createBitmap(DEFAULT_WIDTH, DEFAULT_HEIGHT, Config.ARGB_8888); Canvas canvas = new Canvas(bitmap); code = createCode(); canvas.drawColor(Color.rgb(DEFAULT_COLOR, DEFAULT_COLOR, DEFAULT_COLOR)); Paint paint = new Paint(); paint.setTextSize(DEFAULT_FONT_SIZE); for (int i = 0; i < code.length(); i++) { randomTextStyle(paint); randomPadding(); canvas.drawText(code.charAt(i) + "" , mPaddingLeft, mPaddingTop, paint); } //干扰线 for (int i = 0; i < DEFAULT_LINE_NUMBER; i++) { drawLine(canvas, paint); } canvas.save(Canvas.ALL_SAVE_FLAG);//保存 canvas.restore(); return bitmap; } /** * 得到图片中的验证码字符串 * @return */ public String getCode() { return code; } //生成验证码 public String createCode() { mBuilder.delete(0, mBuilder.length()); //使用之前首先清空内容 for (int i = 0; i < DEFAULT_CODE_LENGTH; i++) { mBuilder.append(CHARS[mRandom.nextInt(CHARS.length)]); } return mBuilder.toString(); } //生成干扰线 private void drawLine(Canvas canvas, Paint paint) { int color = randomColor(); int startX = mRandom.nextInt(DEFAULT_WIDTH); int startY = mRandom.nextInt(DEFAULT_HEIGHT); int stopX = mRandom.nextInt(DEFAULT_WIDTH); int stopY = mRandom.nextInt(DEFAULT_HEIGHT); paint.setStrokeWidth(1); paint.setColor(color); canvas.drawLine(startX, startY, stopX, stopY, paint); } //随机颜色 private int randomColor() { mBuilder.delete(0, mBuilder.length()); //使用之前首先清空内容 String haxString; for (int i = 0; i < 3; i++) { haxString = Integer.toHexString(mRandom.nextInt(0xFF)); if (haxString.length() == 1) { haxString = "0" + haxString; } mBuilder.append(haxString); } return Color.parseColor("#" + mBuilder.toString()); } //随机文本样式 private void randomTextStyle(Paint paint) { int color = randomColor(); paint.setColor(color); paint.setFakeBoldText(mRandom.nextBoolean()); //true为粗体,false为非粗体 float skewX = mRandom.nextInt(11) / 10; skewX = mRandom.nextBoolean() ? skewX : -skewX; paint.setTextSkewX(skewX); //float类型参数,负数表示右斜,整数左斜 // paint.setUnderlineText(true); //true为下划线,false为非下划线 // paint.setStrikeThruText(true); //true为删除线,false为非删除线 } //随机间距 private void randomPadding() { mPaddingLeft += BASE_PADDING_LEFT + mRandom.nextInt(RANGE_PADDING_LEFT); mPaddingTop = BASE_PADDING_TOP + mRandom.nextInt(RANGE_PADDING_TOP); } }
其中,在Default Settings中可以设置验证码图形的大小,验证码的长度,内边距,随机距离等可以根据需要进行调整。
相关推荐
在Android平台上,生成图形验证码(CAPTCHA)是提高应用程序安全性的关键步骤,特别是在用户登录或注册过程中。图形验证码的主要目的是防止自动化的机器人程序或者恶意攻击者进行非法操作,如批量注册、恶意登录等。...
总的来说,理解和实现Android中的随机图形验证码生成,不仅涉及基本的绘图操作,还涉及到颜色、随机数生成等数学知识,以及Android UI组件和内存管理的理解。熟练掌握这一技能对于提高应用的安全性至关重要。
总的来说,自定义验证码生成组件的实现涉及到Android的图形绘制、事件处理和数据交互等多个方面。通过实践,不仅可以提高Android开发技能,也能更好地理解用户体验设计和安全策略在移动应用中的重要性。
在Android开发中,生成验证码图片是一项常见的功能,主要用于提高用户安全性,防止机器人或者恶意软件自动登录或注册。验证码图片通常包含一串随机数字或字母,用户需要手动输入以验证他们是真实的人。以下是对这个...
1. **自动生成验证码**:通常,验证码包含随机生成的一串字符,这些字符可能是数字、字母或其他可识别的图形元素。`CaptchaImageView` 提供了内置的算法来生成这样的随机字符串,并将其转化为图像。 2. **图像扭曲...
7. **库的使用**:有许多开源库可以帮助我们快速实现验证码功能,比如Android的`CaptchaView`或`android-gif-drawable`库,它们提供了预设的动画和图形效果,可以大大简化开发过程。 总结来说,Android中的动态...
移动端获取图形验证码有两种形式,一种是在本地随机生成进行验证,另一种是根据服务端返回的图片流设置到页面上,我们要做的就是根据服务端返回的操作图形验证码工具类。博客地址:...
首先,滑块验证码的核心原理是生成一个不完整或被遮挡的图像,通常包含随机生成的数字、字母或其他图形。用户需要通过滑动滑块将缺失部分与图像对齐,以完成验证。这涉及到图像处理和随机数生成的知识。 在Android...
"git图形验证码"可能是一个误解,因为Git通常指的是版本控制系统,而不是图形验证码。不过,如果这里是指一个特定的库或者组件,它可能是在Android中处理GIF验证码的一个工具。如果这个库存在,它可能提供了方便的...
1. **生成图形验证码**:在前端,我们可以使用canvas API来绘制图形验证码。首先,创建一个canvas元素,然后利用`CanvasRenderingContext2D`对象的绘图方法,如`fillRect`、`strokeRect`等,生成随机的线条、形状和...
综上所述,这个项目涵盖了验证码生成与验证、Android UI设计、网络通信和用户体验优化等多个方面,是学习和实践移动应用开发的好案例。在实际开发中,还需要根据需求进一步完善和优化,确保系统的稳定性和安全性。
总的来说,“android高仿验证码自定义view”是一个涵盖多方面知识的实践项目,涉及Android视图系统、图形绘制、事件处理和随机数生成等技术。通过实践,开发者不仅可以创建出符合应用需求的验证码组件,还能加深对...
在Android应用开发中,生成验证码和二维码是常见的功能,用于增强用户验证的安全性和提供便捷的信息传递方式。这个压缩包文件“Android应用源码--生成验证码和二维码.zip”包含了一个实现这两种功能的示例项目,主要...
图形验证码涉及到图像处理和随机数生成。首先,你需要生成一组随机字符(数字或字母),然后将其转化为图像。在Android中,可以使用Bitmap类创建图像,并使用Canvas进行绘制。字符可以扭曲、旋转、添加噪声以增加...
总的来说,JCreator 4.0结合验证码生成器的开发,为学习和实践Java图形编程、安全机制以及GUI应用提供了一个很好的实践平台。通过这个项目,开发者不仅可以深化对Java语言的理解,还能掌握图形处理和安全验证的相关...
二、验证码生成 1. **随机字符生成**:首先,我们需要生成一串随机的字符序列,这通常包括字母、数字,有时也会包含特殊字符。在Java或Kotlin中,可以使用`Random`类配合字符数组来生成随机字符串。 2. **图形化...
本篇文章将深入探讨如何创建一个自定义View,用于生成随机的图片验证码。验证码是网络安全的重要工具,常用于防止自动化的机器人或恶意软件进行非法操作。 首先,我们需要了解验证码的基本原理。验证码通常由一组...
在Android应用中,生成验证码往往涉及到随机字符生成、图形绘制以及噪线添加等步骤。下面我们将逐步讲解这个过程。 **1. 随机字符生成** 首先,我们需要生成一组随机的字符,这可以是数字、字母或者两者的组合。在...
在Android应用中,验证码通常分为短信验证码和图形验证码两种类型,本示例可能主要涉及的是短信验证码。 在Android中实现自动获取验证码,首先需要集成一个第三方的短信接收SDK,例如阿里云或腾讯云的短信服务。...
在"VerificationCodeTest"这个文件中,很可能是包含了一个验证码测试用例,用于验证我们的验证码生成逻辑是否正确。测试用例通常会包括生成验证码图片、显示图片、比较用户输入与实际验证码的匹配情况等步骤。 实现...