Jump to content
  • 0

[HELP] Saving name color into Database.


Question

Posted

Hello guys, i really need help saving the color i chose into the database.

I made a color manager where I can choose colors, but after i chose for example red it wont save after i do restart (relog).

 

This is the Java code in L2PcInstance:

public void saveName(int color){//
  Connection con = null;
  
try
  {

   con = L2DatabaseFactory.getInstance().getConnection(false);
   PreparedStatement statement;
   statement = con.prepareStatement("UPDATE characters SET name_color=?"+color+" WHERE account_name='"+_accountName+"'");
   statement.setString(1, StringToHex(Integer.toHexString(color).toUpperCase()));
   statement.execute();
   statement.close();
   statement = null;
   getAppearance().setNameColor(color);

   broadcastUserInfo();
  }
  catch(Exception e){}
  finally
  {
   CloseUtil.close(con);
con = null;
  }

}

 

This is the code for one color in python .py file:

if event == "1":
           if st.getQuestItemsCount(57) > 250000:
                st.takeItems(57,250000)
                st.getPlayer().getAppearance().setNameColor(0x009900)
	st.getPlayer().broadcastUserInfo();
                return "1.htm"
            if st.getQuestItemsCount(57) <= 250000:
                return "Announcements: No Enought Adena To Select Color!"
            st.exitQuest(0)

 

How can i make my name color to save after i do restart?

Please answer.

6 answers to this question

Recommended Posts

  • 0
Posted

create a L2PcInstance method which will get the color and save it into the db for example: go to L2PcInstance and create a void like this:

public void storeTittleColor(int color)

{

    //store it in the database

}

 

the go to your py file and add this st.getPlayer.storeTittleColor(the color you want ex:0x009900)

 

  • 0
Posted

- "= null" stuff is pointless.

- your statement sucks : "UPDATE characters SET name_color=?"+color+" WHERE account_name='"+_accountName+"'", parameters should be applied following regular use.

- you create a method named saveName, but don't even use it on your python script. How do you want it works ?

  • 0
Posted

- "= null" stuff is pointless.

- your statement sucks : "UPDATE characters SET name_color=?"+color+" WHERE account_name='"+_accountName+"'", parameters should be applied following regular use.

- you create a method named saveName, but don't even use it on your python script. How do you want it works ?

 

he also uses "where aacountId" this sucks he has to do it by player OID"

  • 0
Posted

i dont know man , every pack connects with your DB diffrent I dont know how your works, if you have h5 i will do this for you when I got free time, but if you dont h5 I won't even try ...

  • 0
Posted

Okay I have remade the code a little and the python file as well.

 

Java Code:

 

	private static final String UPDATE_CHAR_COLOR = "UPDATE character_color SET name_color=?, WHERE charId=?";
public void saveNameColor(int color){

	Connection con = null;
	PreparedStatement statement = null;

	  
	try
	  {

	   con = L2DatabaseFactory.getInstance().getConnection(false);
	   statement = con.prepareStatement(UPDATE_CHAR_COLOR);
	   statement.setString(1, StringToHex(Integer.toHexString(color).toUpperCase()));
	   statement.setInt(2, getObjectId());
	   getAppearance().setNameColor(color);
	   broadcastUserInfo();
	   statement.execute();
	   statement.close();
	  }
	   catch(Exception e){}
	   finally
	   {
	    CloseUtil.close(con);
	   }
}

 

 

Python Code:

        if event == "1":
            if st.getQuestItemsCount(57) > 250000:
                st.takeItems(57,250000)
                st.saveNameColor(0x009900)
                return "1.htm"
            if st.getQuestItemsCount(57) <= 250000:
                return "Announcements: No Enought Adena To Select Color!"
            st.exitQuest(0)

 

But still no luck ://

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

    • Hello, I’m working on decrypting the Init packet that the server sends to the client during login. This packet is treated specially and contains the Blowfish keys used to encrypt and decrypt subsequent packets. Although it isn’t encrypted irreversibly and should be reversible, I haven’t succeeded yet. My goal is to extract the Blowfish key to decrypt certain client packets without disrupting the normal session flow. I can inject a DLL to sniff the packets, and with that I plan to develop a module that extends the client’s functionality. For example, after logging in, this module would capture all the data the client receives (character data, etc.). Additionally, it could listen for real-time server events, enabling integrations with Discord SDKs or other systems, thereby expanding Lineage 2’s capabilities. Init packet(0x00) LoginServer. Currently in the java Cores I checked there is no decode function for this package, only encript.
    • whats password from the archivie ?
    • All that shit are false positives of the vanganth cliext, sources are well and who sell it is a big scammer
    • Information Selling a premium Lineage 2 High Five (L2J) project with active development, available by subscription. Includes Git support and access to compiled or full source code. Ideal for serious server owners seeking stability and performance, uniqueness and well-done features.   General Project Specifications: JDK Version: 23 -> 24 Chronicle: HighFive Structure: Core & Datapack merged into a single project Database: MariaDB Database Driver: HicariCP GIT Website: gitlab.com   Features include (but are not limited to):   1. Tournament Single & Party (Check Youtube Video) 2. Faction (Check Youtube Video) 3. Event Engine (Check Youtube Video) 4. Sell Buff System (Check Youtube Video) 5. Start UP System (Check Youtube Video) 6. User Panel 7. Visual - Dress me System 8. Donate Store 9. Automatic Farm System (Check Youtube Video) 10. Captcha (Anti-BOT) (Check Youtube Video) 11. Auction (Check Youtube Video) 12. Vote (API) 13. Admin Real Time Balance (Check Youtube Video) 14. Achievements (Check Youtube Video) 15. Daily Mission (Check Youtube Video) 16. A.I. Bot (Check Youtube Video) 17. Rebirth 18. Daily Reward  19. Skill Tree - Ability System 20. Craft System 21. Twitch Automatic Reward (Check Youtube Video) 22. Quiz Game (Check Youtube Video) 23. Automatic Item Enchant (Check Youtube Video) 24. Secondary Auth Using Google Authenticator (Check Youtube Video) 25. Gm Shop - Gatekeeper - Scheme Buffer   How to get Access (Payment Subscription): To get Access you either pay monthly subscription to GIT for source or Compiled. Project is currently active and has at least 1-2 commit / day.  Clients in both Compiled & Source subscription can request features or any addon in already existing mods inside discord.   Price per Month (Source) in GIT: 250 Eur Price per Month (Compiled) in GIT: 100 Eur   Contact: To get Access or ask further information join discord  https://discord.gg/gKAsAhJNuq      
  • Topics

×
×
  • Create New...