Jump to content

[Share] Captcha Antibot System [Updated 17.6.2011, Version 2] [Please LOCK IT .]


Recommended Posts

Posted

A fixed number of killed mobs to trigger this can be abused, use random numbers instead.

gz

 

nice share btw :)

Posted

Great share it is working very good, only problem I see is the UPPERCASE letters, is that anyway to make it uppercase or lowercase or even mixed.

It was a lot of players in jail today in my server, most of then for mistakes on the typing, they used lowercase instead. Lot of players got pissed off.

 

Also:

When I used a Dreadnought as a gm and it killed lots of mobs at the same time the window keep changing the code and then sometimes it stop with no code at all. I don't know if a regular char will be able to reproduce that but maybe it they kill 49 mobs and then kill 3 more in one hit (50, 51 and 52) it might happen.

Let me know if the fix above will fix that problem.

 

 

Im sorry coz i havent answered, im also using aoe farming on my pack, 10 mobs per rush impact, and yes it getting more than 50 mobs (for example), but it shows to player only one html (atleast the last one), you can make it with tries if you want to, for example to have 3 times to write it wrong and then punish him, about the UPPERCASE and lowercase letters, check this, it is on L2Attackable after my patch :)!

+		   // Suggestions ----------------------------------------------------------------------
+		   // i removed 1 and l and i because there are confusing to users...
+		   // Z, z, and N also get confusing when rotated
+		   // 0, O, and o are also confusing...
+		   // lowercase G looks a lot like a 9 so i killed it
+		   // this should ideally be done for every language...
+		   // i like controlling the characters though because it helps prevent confusion
+		   // So recommended chars are:
+		   // String elegibleChars = "ABCDEFGHJKLMPQRSTUVWXYabcdefhjkmnpqrstuvwxy23456789";
+		   // Suggestions ----------------------------------------------------------------------
+		   String elegibleChars = "ABCDEFGHJKLMPQRSTUVWXYZ";
+		   char[] chars = elegibleChars.toCharArray();
+

 

 

Just change ""ABCDEFGHJKLMPQRSTUVWXYZ" to the letters you wanna.

("ABCDEFGHJKLMPQRSTUVWXYabcdefhjkmnpqrstuvwxy23456789" are recommented, read the comments, there is reasoning.)

 

Edit: If you want to be sure about html messages and the Mobkill-counter make a check with an output on console :), and check.

Posted

Well first I would suggest the following for the generation of the captcha:

 

	public static BufferedImage generateCaptcha()
{
	final int width = 256;
	final int height = 64;
	final BufferedImage bufferedImage = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
	final Graphics2D g2d = bufferedImage.createGraphics();
	final Font textFont = new Font("verdana", Font.BOLD, 36);
	final Font textFontUpper = new Font("verdana", Font.BOLD | Font.ITALIC, 36);

	RenderingHints renderingHints = new RenderingHints(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
	renderingHints.put(RenderingHints.KEY_RENDERING, RenderingHints.VALUE_RENDER_QUALITY);
	g2d.setRenderingHints(renderingHints);

	Color textColor = new Color(98, 213, 43);
	Color circleColor = new Color(98, 213, 43);

	int charsToPrint = 5;
	int circlesToDraw = 8;
	float horizMargin = 20.0f;
	double rotationRange = 0.7; // this is radians

	Graphics2D g = (Graphics2D) bufferedImage.getGraphics();

	//Draw an oval
	g.setColor(new Color(30,31,31));
	g.fillRect(0, 0, width, height);

	// lets make some noisey circles
	g.setColor(circleColor);

	for (int i=0; i<circlesToDraw; i++)
	{
		int circleRadius = (int) (Math.random() * height / 2.0);
		int circleX = (int) (Math.random() * width - circleRadius);
		int circleY = (int) (Math.random() * height - circleRadius);
		g.drawOval(circleX, circleY, circleRadius * 2, circleRadius * 2);
	}

	g.setColor(textColor);
	g.setFont(textFont);

	FontMetrics fontMetrics = g.getFontMetrics();
	int maxAdvance = fontMetrics.getMaxAdvance();
	int fontHeight = fontMetrics.getHeight();

	// Suggestions ----------------------------------------------------------------------
	// i removed 1 and l and i because there are confusing to users...
	// Z, z, and N also get confusing when rotated
	// 0, O, and o are also confusing...
	// lowercase G looks a lot like a 9 so i killed it
	// this should ideally be done for every language...
	// i like controlling the characters though because it helps prevent confusion
	// So recommended chars are:
	// String elegibleChars = "ABCDEFGHJKLMPQRSTUVWXYabcdefhjkmnpqrstuvwxy23456789";
	// Suggestions ----------------------------------------------------------------------
	String elegibleChars = "abcdefghjijkmnpqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ123456789";
	char[] chars = elegibleChars.toCharArray();

	float spaceForLetters = -horizMargin * 2 + width;
	float spacePerChar = spaceForLetters / (charsToPrint - 1.0f);

	for (int i=0; i<charsToPrint; i++)
	{
		double randomValue = Math.random();
		int randomIndex = (int) Math.round(randomValue * (chars.length - 1));
		char characterToShow = chars[randomIndex];
		finalString.append(characterToShow);

		// this is a separate canvas used for the character so that
		// we can rotate it independently
		int charWidth = fontMetrics.charWidth(characterToShow);
		int charDim = Math.max(maxAdvance, fontHeight);
		int halfCharDim = (charDim / 2);

		BufferedImage charImage = new BufferedImage(charDim, charDim, BufferedImage.TYPE_INT_ARGB);
		Graphics2D charGraphics = charImage.createGraphics();
		charGraphics.translate(halfCharDim, halfCharDim);
		double angle = (Math.random() - 0.5) * rotationRange;
		charGraphics.transform(AffineTransform.getRotateInstance(angle));
		charGraphics.translate(-halfCharDim,-halfCharDim);
		charGraphics.setColor(textColor);
		charGraphics.setFont(textFont);

		int charX = (int) (0.5 * charDim - 0.5 * charWidth);
		charGraphics.drawString("" + characterToShow, charX,
				((charDim - fontMetrics.getAscent())
						/ 2 + fontMetrics.getAscent()));

		float x = horizMargin + spacePerChar * (i) - charDim / 2.0f;
		int y = ((height - charDim) / 2);

		if(Character.isDigit(chars[i]) || Character.isLowerCase(chars[i]))
			g2d.setFont(textFont);
		else
			g2d.setFont(textFontUpper);

		g.drawImage(charImage, (int) x, y, charDim, charDim, null, null);

		charGraphics.dispose();
	}

	g.dispose();

	return bufferedImage;
}

 

And next the following to load it:

 

			final int sId = Config.SERVER_ID;
		int imgId = IdFactory.getInstance().getNextId();

		try
		{
			//File captcha = new File("data/captcha/captcha.png");
			ByteArrayOutputStream bts = new ByteArrayOutputStream();
			ImageIO.write(generateCaptcha(), "png", bts);

			//ImageIO.write(generateCaptcha(), "png", captcha);
			byte[] buffer = bts.toByteArray();
			ByteArrayInputStream bis = new ByteArrayInputStream (buffer, 0, buffer.length);
			PledgeCrest packet = new PledgeCrest(imgId, DDSConverter.convertToDDS(bis).array());
			playerInstance.sendPacket(packet);
		}
		catch (Exception e)
		{
			...

Posted

Well first I would suggest the following for the generation of the captcha:

 

	public static BufferedImage generateCaptcha()
{
	final int width = 256;
	final int height = 64;
	final BufferedImage bufferedImage = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
	final Graphics2D g2d = bufferedImage.createGraphics();
	final Font textFont = new Font("verdana", Font.BOLD, 36);
	final Font textFontUpper = new Font("verdana", Font.BOLD | Font.ITALIC, 36);

	RenderingHints renderingHints = new RenderingHints(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
	renderingHints.put(RenderingHints.KEY_RENDERING, RenderingHints.VALUE_RENDER_QUALITY);
	g2d.setRenderingHints(renderingHints);

	Color textColor = new Color(98, 213, 43);
	Color circleColor = new Color(98, 213, 43);

	int charsToPrint = 5;
	int circlesToDraw = 8;
	float horizMargin = 20.0f;
	double rotationRange = 0.7; // this is radians

	Graphics2D g = (Graphics2D) bufferedImage.getGraphics();

	//Draw an oval
	g.setColor(new Color(30,31,31));
	g.fillRect(0, 0, width, height);

	// lets make some noisey circles
	g.setColor(circleColor);

	for (int i=0; i<circlesToDraw; i++)
	{
		int circleRadius = (int) (Math.random() * height / 2.0);
		int circleX = (int) (Math.random() * width - circleRadius);
		int circleY = (int) (Math.random() * height - circleRadius);
		g.drawOval(circleX, circleY, circleRadius * 2, circleRadius * 2);
	}

	g.setColor(textColor);
	g.setFont(textFont);

	FontMetrics fontMetrics = g.getFontMetrics();
	int maxAdvance = fontMetrics.getMaxAdvance();
	int fontHeight = fontMetrics.getHeight();

	// Suggestions ----------------------------------------------------------------------
	// i removed 1 and l and i because there are confusing to users...
	// Z, z, and N also get confusing when rotated
	// 0, O, and o are also confusing...
	// lowercase G looks a lot like a 9 so i killed it
	// this should ideally be done for every language...
	// i like controlling the characters though because it helps prevent confusion
	// So recommended chars are:
	// String elegibleChars = "ABCDEFGHJKLMPQRSTUVWXYabcdefhjkmnpqrstuvwxy23456789";
	// Suggestions ----------------------------------------------------------------------
	String elegibleChars = "abcdefghjijkmnpqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ123456789";
	char[] chars = elegibleChars.toCharArray();

	float spaceForLetters = -horizMargin * 2 + width;
	float spacePerChar = spaceForLetters / (charsToPrint - 1.0f);

	for (int i=0; i<charsToPrint; i++)
	{
		double randomValue = Math.random();
		int randomIndex = (int) Math.round(randomValue * (chars.length - 1));
		char characterToShow = chars[randomIndex];
		finalString.append(characterToShow);

		// this is a separate canvas used for the character so that
		// we can rotate it independently
		int charWidth = fontMetrics.charWidth(characterToShow);
		int charDim = Math.max(maxAdvance, fontHeight);
		int halfCharDim = (charDim / 2);

		BufferedImage charImage = new BufferedImage(charDim, charDim, BufferedImage.TYPE_INT_ARGB);
		Graphics2D charGraphics = charImage.createGraphics();
		charGraphics.translate(halfCharDim, halfCharDim);
		double angle = (Math.random() - 0.5) * rotationRange;
		charGraphics.transform(AffineTransform.getRotateInstance(angle));
		charGraphics.translate(-halfCharDim,-halfCharDim);
		charGraphics.setColor(textColor);
		charGraphics.setFont(textFont);

		int charX = (int) (0.5 * charDim - 0.5 * charWidth);
		charGraphics.drawString("" + characterToShow, charX,
				((charDim - fontMetrics.getAscent())
						/ 2 + fontMetrics.getAscent()));

		float x = horizMargin + spacePerChar * (i) - charDim / 2.0f;
		int y = ((height - charDim) / 2);

		if(Character.isDigit(chars[i]) || Character.isLowerCase(chars[i]))
			g2d.setFont(textFont);
		else
			g2d.setFont(textFontUpper);

		g.drawImage(charImage, (int) x, y, charDim, charDim, null, null);

		charGraphics.dispose();
	}

	g.dispose();

	return bufferedImage;
}

 

And next the following to load it:

 

			final int sId = Config.SERVER_ID;
		int imgId = IdFactory.getInstance().getNextId();

		try
		{
			//File captcha = new File("data/captcha/captcha.png");
			ByteArrayOutputStream bts = new ByteArrayOutputStream();
			ImageIO.write(generateCaptcha(), "png", bts);

			//ImageIO.write(generateCaptcha(), "png", captcha);
			byte[] buffer = bts.toByteArray();
			ByteArrayInputStream bis = new ByteArrayInputStream (buffer, 0, buffer.length);
			PledgeCrest packet = new PledgeCrest(imgId, DDSConverter.convertToDDS(bis).array());
			playerInstance.sendPacket(packet);
		}
		catch (Exception e)
		{
			...

 

Can you please give us reasoning? As i can see you have changed the font and added all letters/numbers....

Posted

awesome good job man!

 

Question: it is possible if i whant to disable jail and just the character to stay in freezing mode or to disable the if you write also wrong you get jail for 1 minute?

Posted

awesome good job man!

 

Question: it is possible if i whant to disable jail and just the character to stay in freezing mode or to disable the if you write also wrong you get jail for 1 minute?

 

Well, yes, its simple, everywhere you can see this

+                                       activeChar.setPunishLevel(L2PcInstance.PunishLevel.JAIL, 1);

... Just delete it! This is the "method" that jails the player.

Guest
This topic is now closed to further replies.



  • Posts

    • MoMoProxy has updated more static residential proxies for USA location, anyone interested in can view: https://momoproxy.com/static-residential-proxies
    • This post originally appeared on MmoGah.   Dear Exiles, here's a detailed guide for Path of Exile 3.26 Gauntlet, tailored for beginners and focused on the top 5 builds that balance survivability, damage, and ease of gearing in the Hardcore Solo Self-Found (HCSSF) environment. This guide goes deep into mechanics, gear, leveling, and strategy—no fluff, just actionable insights.       What Is the Gauntlet in PoE 3.26? The Gauntlet is a community-run event, often organized by Zizaran, which pushes players into a brutal version of the game:   ● Hardcore Solo Self-Found (HCSSF): No trading, no partying, no outside help. ● Global Modifiers: Increased monster damage, life, elemental penetration, extra projectiles, and more. ● Limited Portals: Only 3 portals per boss kill count toward points. ● Custom Ascendancies: In 3.26, the Fishia League introduces new ascendancy classes like Ancestral Commander and Servant of Arakali.   The goal? Survive, level up, kill bosses, and earn points for prizes. But first, you need a build that won't crumble under pressure.   Top 5 Builds for Gauntlet Beginners These builds are chosen for their tankiness, simplicity, and ability to progress through the campaign and early maps with minimal gear.   1. Raise Zombie Puppeteer (Necromancer) Why It Works: Minions absorb damage, keeping you safe. Scales well with minimal gear. Strong bossing potential with high zombie levels.   Core Mechanics: Uses Raise Zombie as the main damage source. Strength stacking boosts zombie power. Animate Guardian adds utility and buffs.   Defensive Layers: Minions tank hits. Block chance from gear and passive tree. Energy shield and life stacking.   Leveling Tips: Use Summon Skeletons and Raise Zombie early. Prioritize +minion gem levels and strength gear. Transition to spectres and Animate Guardian by Act 5.   Pros: Safe, ranged playstyle. Easy to gear in SSF. Strong boss damage.   Cons: Minion AI can be clunky. Damage may taper off in the late game without investment.   2. Power Siphon Mines (Scavenger Saboteur) Why It Works: Ranged mine playstyle avoids direct damage. One-button mechanics for comfort. Fast leveling and strong suppression.   Core Mechanics: Power Siphon linked to mines for remote detonation. Uses High-Impact Mine Support and Minefield Support. Cloak of Flames for early damage scaling.   Defensive Layers: High evasion and suppression. Life stacking and stun immunity. Arctic Armor and Flesh and Stone for mitigation.   Leveling Tips: Start with Stormblast Mine or Explosive Trap. Switch to Power Siphon at level 28. Use Smoke Mine and Flame Dash for mobility.   Pros: Safe ranged playstyle. Low gear dependency. Comfortable mechanics.   Cons: Mines require setup. It can feel clunky without proper gem links.   3. Ice Nova Archmage (Hierophant) Why It Works: Combines Mind Over Matter (MoM) with mana stacking. Strong AoE and single-target damage. Good defenses and smooth leveling.   Core Mechanics: Ice Nova cast on Frostbolt for double damage. Archmage Support scales damage with mana. Hierophant ascendancy boosts mana and endurance charges.   Defensive Layers: MoM absorbs damage via mana. High armor and resistances. Chill and freeze for crowd control.   Leveling Tips: Start with Holy Flame Totem or Rolling Magma. Switch to Ice Nova after Act 3. Stack mana and use Clarity early.   Pros: Strong defenses and damage. Scales well into the endgame. Beginner-friendly caster setup.   Cons: Requires mana management. Squishy if not geared properly.   4. Explosive Arrow Ballista (Ancestral Commander) Why It Works: Totems do the work while you stay safe. Easy to gear and scale. Great for campaign progression.   Core Mechanics: Explosive Arrow linked to Ballista Totem Support. Totems stack arrows for massive explosions. Ancestral Commander ascendancy grants endurance charges and slam synergy.   Defensive Layers: Totems absorb aggro. High life and resistances. Fortify from gear or ascendancy.   Leveling Tips: Use Caustic Arrow or Split Arrow early. Switch to Explosive Arrow at level 28. Prioritize attack speed and totem placement.   Pros: Safe, passive playstyle. Strong single-target damage. Easy to respec and adapt.   Cons: Totem AI can be slow. Requires positioning for optimal damage.   5. Lightning Strike Daughter of Oshabi Why It Works: High energy shield and shrine buffs. Converts physical damage to chaos. Fast, clear, and strong bossing.   Core Mechanics: Lightning Strike with pure energy shield gear. Oath of the Magi node doubles armor defenses. Ghost Dance for ES sustain.   Defensive Layers: 10,000+ energy shield. Suppression and resist caps. Stun immunity and chaos conversion.   Leveling Tips: Use Smite or Molten Strike early. Transition to Lightning Strike with ES gear. Stack shrine buffs and movement speed.   Pros: Tanky and fast. Handles tier 17 maps. Good for face-tanking bosses.   Cons: Requires ES gear early. Shrine RNG can affect consistency.   Beginner Tips for Gauntlet Success Campaign Strategy: Overlevel before boss fights. Cap resistances ASAP. Use movement skills to dodge mechanics. Practice Acts 1, 4, and 9—they're deadly.   Gear Prioritization: Life and resistances > damage. Movement speed on boots. Vendor recipes for gear upgrades.   Flask Setup: 1 Instant Life Flask 1 Granite Flask 1 Jade Flask 1 Quicksilver Flask 1 Utility Flask (e.g., Sulphur or Basalt)   Passive Tree Tips: Prioritize life nodes early. Take suppression and block nodes. Avoid complex mechanics—simplicity wins.   Mapping and Bossing Strategy Mapping: Use fast-clearing skills. Avoid risky map mods. Keep portals in reserve.   Bossing: Learn boss mechanics. Use Sniper's Mark or Assassin's Mark. Position mercenaries or totems strategically.   Final Thoughts The Gauntlet is unforgiving, but with the right build and mindset, you can push deep into the event—even as a beginner. Focus on survivability, learn from each death, and don't be afraid to restart. Every run teaches you something new.
    • SocNet x Dolphin Anty Partnership — Reaching New Heights Together! We’re excited to announce our new partnership with the anti-detect browser Dolphin Anty! Thank you for your trust and support — it's because of you that we continue to grow, expand, and bring even more value and opportunities to our customers. This partnership with Dolphin Anty offers more convenience, security, and flexibility for your work and automation needs. Read more on Dolphin Anty’s official blog: https://dolphin-anty.com/blog/en/socnet-and-dolphin-anty/ We’re also looking for new suppliers! — Snapchat accounts — Reddit accounts with karma — LinkedIn accounts with connections Contact us via DM or support to discuss terms — we’re always open to partnership proposals! Explore our online store: ➡ Accounts: Telegram, Facebook, Reddit, Twitter (X), Instagram, YouTube, TikTok, Discord, VK, LinkedIn, GitHub, Snapchat, Gmail, and emails (Outlook, Firstmail, Rambler, Onet, Gazeta, GMX, Yahoo, Proton, Web.de), Google Voice, Google Ads ➡ Premium Subscriptions: Telegram Premium, Twitter X Premium, YouTube Premium, Spotify Premium, Netflix Premium, Discord Nitro, ChatGPT Plus/PRO, XBOX Game Pass ➡ Additional Services: Telegram Stars, proxies (IPv4, IPv6, ISP, Mobile), VPNs (Outline, WireGuard, others), VDS/RDP servers To celebrate the partnership, use promo code DOLPHIN15 for 15% off in our online store! SMM Panel Services: ➡ Use our SMM Panel to boost: Facebook, Instagram, Telegram, Spotify, SoundCloud, YouTube, Reddit, Threads, Kick, Discord, LinkedIn, Likee, VK, Twitch, Kwai, website traffic, TikTok, TrustPilot, Apple Music, TripAdvisor, Snapchat, and more. Get $1 Trial Credit for your first SMM Panel launch: Just submit a support ticket titled "Get Trial Bonus" on our website. ➡ Go to the SMM Panel (clickable) or contact support via bot. Our Key Products: ➡ Online Store: Click ➡ Telegram Store Bot: Click ➡ SMM Panel: Click Payment methods: bank cards · crypto · other popular methods Returning customers get extra discounts & promo codes! Support Contacts: ➡ Telegram: https://t.me/solomon_bog ➡ Discord: https://discord.gg/y9AStFFsrh ➡ WhatsApp: https://wa.me/79051904467 ➡ ✉ Email: solomonbog@socnet.store ➡ Telegram Channel: https://t.me/accsforyou_shop You can also use these contacts to: — consult about bulk purchases — propose partnerships (our partners: https://socnet.bgng.io/partners ) — become a supplier SocNet — Digital Goods & Premium Subscriptions Store
  • Topics

×
×
  • Create New...

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock