Jump to content
  • 0

.change L2Jacis


Question

Posted

Hello, I'm creating a code for users to change passwords for a .change command, but I'm not able to get an html for the code. I've taken a part of a npc and help me code it down

 

 

/*
 * This program is free software: you can redistribute it and/or modify it under
 * the terms of the GNU General Public License as published by the Free Software
 * Foundation, either version 3 of the License, or (at your option) any later
 * version.
 * 
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
 * details.
 * 
 * You should have received a copy of the GNU General Public License along with
 * this program. If not, see <http://www.gnu.org/licenses/>.
 */
package net.sf.l2j.gameserver.handler.voicedcommandhandlers;
 
import java.security.MessageDigest;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.Base64;
import java.util.StringTokenizer;
import java.util.logging.Logger;
 
import net.sf.l2j.commons.concurrent.ThreadPool;
 
import net.sf.l2j.L2DatabaseFactory;
import net.sf.l2j.gameserver.handler.IVoicedCommandHandler;
import net.sf.l2j.gameserver.model.actor.instance.L2PcInstance;
 
/**
 * @author williams
 *
 */
public class ChangePassword implements IVoicedCommandHandler
{
private static final Logger _log = Logger.getLogger(ChangePassword.class.getName());
 
private static final String[] _voicedCommands =
{
"change"
};
 
@Override
public boolean useVoicedCommand(String command, L2PcInstance activeChar, String target)
{
if(command.equalsIgnoreCase("change") && target != null)
{
StringTokenizer st = new StringTokenizer(target);
st.nextToken();
String curPass = null;
String newPass = null;
String repPass = null;
try
{
if (st.hasMoreTokens())
{
curPass = st.nextToken();
newPass = st.nextToken();
repPass = st.nextToken();
}
else
{
activeChar.sendMessage("Please fill in all the blanks before requesting for a password change.");
return false;
}
changePassword(curPass, newPass, repPass, activeChar);
}
catch (StringIndexOutOfBoundsException e)
{
e.printStackTrace();
}
}
return false;
}
 
@SuppressWarnings("null")
public static boolean changePassword(String currPass, String newPass, String repeatNewPass, L2PcInstance activeChar)
{
if (newPass.length() < 3)
{
activeChar.sendMessage("The new password is too short!");
return false;
}
if (newPass.length() > 16)
{
activeChar.sendMessage("The new password is too long!");
return false;
}
if (!newPass.equals(repeatNewPass))
{
activeChar.sendMessage("Repeated password doesn't match the new password.");
return false;
}
 
Connection con = null;
String password = null;
try
{
MessageDigest md = MessageDigest.getInstance("SHA");
byte[] raw = currPass.getBytes("UTF-8");
raw = md.digest(raw);
String currPassEncoded = Base64.getEncoder().encodeToString(raw);
 
con = L2DatabaseFactory.getInstance().getConnection();
PreparedStatement statement = con.prepareStatement("SELECT password FROM accounts WHERE login=?");
statement.setString(1, activeChar.getAccountName());
ResultSet rset = statement.executeQuery();
while (rset.next())
{
password = rset.getString("password");
}
rset.close();
statement.close();
byte[] password2 = null;
if (currPassEncoded.equals(password))
{
password2 = newPass.getBytes("UTF-8");
password2 = md.digest(password2);
 
PreparedStatement statement2 = con.prepareStatement("UPDATE accounts SET password=? WHERE login=?");
statement2.setString(1, Base64.getEncoder().encodeToString(password2));
statement2.setString(2, activeChar.getAccountName());
statement2.executeUpdate();
statement2.close();
 
activeChar.sendMessage("Your password has been changed successfully! For security reasons, You will be disconnected in 3 Seconds. Please login again!");
try
{
ThreadPool.schedule(() -> activeChar.logout(false), 3000);
}
catch (Exception e)
{
{
e.printStackTrace();
}
}
 
activeChar.broadcastUserInfo();
activeChar.decayMe();
activeChar.spawnMe();
}
else
{
activeChar.sendMessage("The current password you've inserted is incorrect! Please try again!");
 
return password2 != null;
}
}
catch (Exception e)
{
_log.warning("could not update the password of account: " + activeChar.getAccountName());
e.printStackTrace();
}
finally
{
if (con != null)
try
{
con.close();
con = null;
}
catch (final Throwable e){}
}
return true;
}
 
@Override
public String[] getVoicedCommandList()
{
return _voicedCommands;
} 
}

2 answers to this question

Recommended Posts

  • 0
Posted

Hello, I'm creating a code for users to change passwords for a .change command, but I'm not able to get an html for the code. I've taken a part of a npc and help me code it down

 

 

/*
 * This program is free software: you can redistribute it and/or modify it under
 * the terms of the GNU General Public License as published by the Free Software
 * Foundation, either version 3 of the License, or (at your option) any later
 * version.
 * 
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
 * details.
 * 
 * You should have received a copy of the GNU General Public License along with
 * this program. If not, see <http://www.gnu.org/licenses/>.
 */
package net.sf.l2j.gameserver.handler.voicedcommandhandlers;
 
import java.security.MessageDigest;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.Base64;
import java.util.StringTokenizer;
import java.util.logging.Logger;
 
import net.sf.l2j.commons.concurrent.ThreadPool;
 
import net.sf.l2j.L2DatabaseFactory;
import net.sf.l2j.gameserver.handler.IVoicedCommandHandler;
import net.sf.l2j.gameserver.model.actor.instance.L2PcInstance;
 
/**
 * @author williams
 *
 */
public class ChangePassword implements IVoicedCommandHandler
{
private static final Logger _log = Logger.getLogger(ChangePassword.class.getName());
 
private static final String[] _voicedCommands =
{
"change"
};
 
@Override
public boolean useVoicedCommand(String command, L2PcInstance activeChar, String target)
{
if(command.equalsIgnoreCase("change") && target != null)
{
StringTokenizer st = new StringTokenizer(target);
st.nextToken();
String curPass = null;
String newPass = null;
String repPass = null;
try
{
if (st.hasMoreTokens())
{
curPass = st.nextToken();
newPass = st.nextToken();
repPass = st.nextToken();
}
else
{
activeChar.sendMessage("Please fill in all the blanks before requesting for a password change.");
return false;
}
changePassword(curPass, newPass, repPass, activeChar);
}
catch (StringIndexOutOfBoundsException e)
{
e.printStackTrace();
}
}
return false;
}
 
@SuppressWarnings("null")
public static boolean changePassword(String currPass, String newPass, String repeatNewPass, L2PcInstance activeChar)
{
if (newPass.length() < 3)
{
activeChar.sendMessage("The new password is too short!");
return false;
}
if (newPass.length() > 16)
{
activeChar.sendMessage("The new password is too long!");
return false;
}
if (!newPass.equals(repeatNewPass))
{
activeChar.sendMessage("Repeated password doesn't match the new password.");
return false;
}
 
Connection con = null;
String password = null;
try
{
MessageDigest md = MessageDigest.getInstance("SHA");
byte[] raw = currPass.getBytes("UTF-8");
raw = md.digest(raw);
String currPassEncoded = Base64.getEncoder().encodeToString(raw);
 
con = L2DatabaseFactory.getInstance().getConnection();
PreparedStatement statement = con.prepareStatement("SELECT password FROM accounts WHERE login=?");
statement.setString(1, activeChar.getAccountName());
ResultSet rset = statement.executeQuery();
while (rset.next())
{
password = rset.getString("password");
}
rset.close();
statement.close();
byte[] password2 = null;
if (currPassEncoded.equals(password))
{
password2 = newPass.getBytes("UTF-8");
password2 = md.digest(password2);
 
PreparedStatement statement2 = con.prepareStatement("UPDATE accounts SET password=? WHERE login=?");
statement2.setString(1, Base64.getEncoder().encodeToString(password2));
statement2.setString(2, activeChar.getAccountName());
statement2.executeUpdate();
statement2.close();
 
activeChar.sendMessage("Your password has been changed successfully! For security reasons, You will be disconnected in 3 Seconds. Please login again!");
try
{
ThreadPool.schedule(() -> activeChar.logout(false), 3000);
}
catch (Exception e)
{
{
e.printStackTrace();
}
}
 
activeChar.broadcastUserInfo();
activeChar.decayMe();
activeChar.spawnMe();
}
else
{
activeChar.sendMessage("The current password you've inserted is incorrect! Please try again!");
 
return password2 != null;
}
}
catch (Exception e)
{
_log.warning("could not update the password of account: " + activeChar.getAccountName());
e.printStackTrace();
}
finally
{
if (con != null)
try
{
con.close();
con = null;
}
catch (final Throwable e){}
}
return true;
}
 
@Override
public String[] getVoicedCommandList()
{
return _voicedCommands;
} 
}
 
Because there no html in code you have to write it in chat..
  • 0
Posted
command.equalsIgnoreCase("change")

This should be:

command.startsWith("change")

This:

StringTokenizer st = new StringTokenizer(target);

Should be:

StringTokenizer st = new StringTokenizer(command);

Make sure you register the voiced command in VoicedCommandHandler. The command works like: .change currentpass newpass newpass

 

However, the checks are not correct and if someone presses for example .change currentpass newpass (he doesn't repeat the new pass) you are going to get an error. (if (st.hasMoreTokens() will return true even if it has 1 more token, when you need 3 more tokens. Try st.countTokens().)

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Answer this question...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.



  • Posts

    • Our sales are ongoing. Bump. 02 July 2025 Telegram: ContactDiscordAccS
    • Our sales are ongoing. Bump. 02 July 2025 Telegram: ContactDiscordAccS
    • just with this extender that I have shared it is not possible to start with c4 client, you have to make some changes to the extender and it works with c4 client perfectly. regarding the updates in this last revision   🔹dll is not packaged with vmprotect   New custom zone types have been added: 🔹 NO_NOBLESS begin MinX=84638 MaxX=92616 MinY=-87170 MaxY=-82018 MinZ=-6000 MaxZ=0 Type=NO_NOBLESS KickOutPos=83007/148057/-3464 end   ▶️ This zone checks if the character is noble. If it does not meet the condition, it will be automatically kicked to the indicated position (KickOutPos). 🔹 CUSTOM_SPAWN_ZONE begin MinX=77275 MaxX=85704 MinY=10122 MaxY=18066 MinZ=-8000 MaxZ=5000 Type=CUSTOM_SPAWN_ZONE OutPos=83007/148057/-3464 Spawns={{82984/18066/-5256}};{{79275/15147/-5248}};{{82922/14263/-5256}};{{83704/10122/-5288}} end ▶️ This zone allows characters, upon death, to respawn with full buff, CP, HP and MP if they press “Fixed”. They will only be able to revive in one of the positions defined in Spawns. 🔧 Both zones are fully configurable from territorydata.txt 🔧 Development Repository (SVN) GX-EXT supports open, collaborative, and professional development. That’s why we provide access to our public SVN repository where you can:   ✅ Compile your own version of the project ✅ Optimize and extend its features ✅ Learn from real production-quality source code   🔒 Delayed access: The repository is always 2 months behind the latest commercial release to prevent unauthorized reselling.   🔗 SVN URL: https://svn.l2servers.com.ar/!/#GX-EXT_INTERLUDE Username: gx Password: gx   You can use tools like TortoiseSVN to download and work with the code.
    • Could you tell me what changed in this update?   more one question: Is it possible to log in through the c4 client instead of interlude? That would be great  
    • ➡ Discount for your purchase: JULY2025 (11% discount) ➡ Our Online Shop: https://socnet.store  ➡ Our SMM-Boosting Panel: https://socnet.pro  ➡ Telegram Shop Bot: https://socnet.shop  ➡ Telegram Support: https://t.me/solomon_bog  ➡ Telegram Channel: https://t.me/accsforyou_shop  ➡ Discord Support: @AllSocialNetworksShop  ➡ Discord Server: https://discord.gg/y9AStFFsrh  ➡ WhatsApp Support: https://wa.me/79051904467 ➡ WhatsApp Channel: https://whatsapp.com/channel/0029Vau0CMX002TGkD4uHa2n  ➡ Email Support: solomonbog@socnet.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