Jump to content

[Share] Emergency teleport on your website (PHP, JS)


Recommended Posts

Since i've been making new epilogue server, i made a lot of scripts, so im posting some here :)

 

this one will teleport given character to some location (in radius 30)

 

 

Protections: simple antibot protection (bots usually cant use javascript), protection against sql injection etc

What does it do: simple login to your account, picture of characters of that account (and you choose one char), teleport to given location

 

 

So

 

First, make file called index.php, inside this file insert this

<script type="text/javascript">
function login_teleport(){
user=document.getElementById("user");
password=document.getElementById("password");
if(user.value==""){
alert("Empty username");
}else if(password.value==""){
alert("Empty password");
}else{
document.getElementById("login").submit();
}
}
</script>
<h1>Emergency teleport</h1>
<form id="login" action="login.php" method="POST">
Username : <input type="text" id="user" name="user" /><br />
Password : <input type="password" id="password" name="password" /><br />
<input type="button" value="login" onclick="javascript:login_teleport();" />
</form>

 

 

then create file called login.php, inside it insert

<?php
session_start();

if(!empty($_POST["user"])){
include('config.php');

$query=sprintf("SELECT login,password FROM accounts WHERE login='%s' LIMIT 1",mysql_real_escape_string($_POST["user"]));
$row=mysql_fetch_array(mysql_query($query));

echo $row["login"];
if($row["login"] != null){
$password=$_POST["password"];
$password_crypted=base64_encode(pack("H*",sha1(utf8_encode($password))));

if($row["password"]==$password_crypted){
$_SESSION["user"]=$row["login"];
	print '
	<script type="text/javascript">
	document.location="teleport.php";
	</script>
	';

}
else{
print '
<script type="text/javascript">
alert("Wrong password");
document.location="index.php";
</script>
';

}

}else{

print '
<script type="text/javascript">
alert("Wrong username");
document.location="index.php";
</script>
';

}
}

?>

 

then file teleport.php

<?php
session_start();

if($_SESSION["user"]!=null){

include('config.php');



if(!empty($_POST["char"])){

$loc_x=$loc_x-$radius+rand(0,$radius*2);
$loc_y=$loc_y-$radius+rand(0,$radius*2);
$query=sprintf("UPDATE `characters` SET `x` = '%d',`y` = '%d',`z` = '%d' WHERE `charId` =%d;", $loc_x, $loc_y, $loc_z, mysql_real_escape_string($_POST["char"]));
if(mysql_query($query)){
print "<h2>Successfully teleported</h2>";
}else{
print '<h2>' . mysql_errno() . ':' . mysql_error();
}
print "<br /><hr /><br />";


}
$query=mysql_query("SELECT charId,char_name FROM characters WHERE account_name = '" . $_SESSION["user"] . "'");

print 'This will teleport you to Town of Giran : center';
print '<br /><br />';
print "Please select your character";

print '<form action="teleport.php" method="POST">';
print '<select name="char">';
while($row=mysql_fetch_array($query)){
	print('<option value="' . $row["charId"] . '">' . $row["char_name"] .'</option>');
}
print '</select>';
print '<input type="submit" value="Teleport" />';
print '</form>';
print '<br /><br /><br />';
print '<a href="logout.php">Logout</a>';
}
else{
header("Location: index.php");
}

?>

 

then logout.php

<?php
session_start();
session_destroy();
header("Location: index.php");
?>

 

and finally config.php

<?php
mysql_connect("localhost","root","password") or die(mysql_error());
mysql_select_db("l2jdb") or die(mysql_error());


$loc_x="83369";
$loc_y="148606";
$loc_z="-3404";

$radius="30";

?>

(in place of localhost put your mysql host, root is username, password is password and l2jdb is mysql database)

 

$loc_x,$loc_y,$loc_z are coordinates (in game try /loc, it will show you your current location)

 

Beware: Choose only large area (teleport is random, so like 20 persons wont be on the same position) (radius 30, change it if you want)

 

 

 

 

if you want only php function, there it is

function teleport($loc_x,$loc_y,$loc_z,$radius,$charId){
$loc_x=$loc_x-$radius+rand(0,$radius*2);
	$loc_y=$loc_y-$radius+rand(0,$radius*2);
	$query=sprintf("UPDATE `characters` SET `x` = '%d',`y` = '%d',`z` = '%d' WHERE `charId` =%d;", $loc_x, $loc_y, $loc_z, mysql_real_escape_string($charId));
	if(mysql_query($query)){
print "<h2>Successfully teleported</h2>";
}else{
print '<h2>' . mysql_errno() . ':' . mysql_error();
}
}

 

usage

 

<?php
teleport("location x","location y","location z", "radius", "character ID selected from database");
?>

 

 

 

 

 

and finally : direct download to whole script :) (on private ftp, so this has hide)

This is the hidden content, please

 

 

 

Credits : DarkKnight / DarkKnightCZ

Link to comment
Share on other sites

ExTrEmEDwarf: what hole? if you change input on login, wont work (every protection against it in login.php (mysql_real_escape_string, sprintf) ) , if you change input inside it, the same thing (m_r_e_s, sprintf), but i you know some hole in it, post it, i will repair it :)

Link to comment
Share on other sites

  • 1 month later...

i am sorry if i making a stupid question but this wont allow players to exploit the feature? for example teleporting themselves in giran while giran is in siege which normally shouldn't or teleporting from place to place without using gk and this way dont spend adena? (at low rate servers that matters). can be modified to have restrictions?

Link to comment
Share on other sites

  • 2 years later...

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
Reply to this topic...

×   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

    • Well, sorry not sorry for resurrecting old topic, but I believe it's ultimately stupid to implement license checks like Vilmis did 🙂   private static String url = "jdbc:mysql://185.80.128.233/" + getData("Zm9ydW1fZGI="); private static String username = getData("bXJjb3B5cmlnaHQ="); private static String password = getData("Y29weXJpZ2h0XzEyMw=="); con = GlobalDB.getInstance().getConnection(); PreparedStatement statement; statement = con.prepareStatement("SELECT field_6 from core_pfields_content WHERE member_id = ?"); statement.setInt(1, Config.FORUM_USER_ID); ResultSet rset = statement.executeQuery();   This awesome way of coding things leaves us with base64-encoded credentials and DB exposed and accessible globally 😉 Btw he checks his licensing data from some plugin generated table his forum uses. Vilmis took action and ensured that mrcopyright user would have only needed accesses and rights for this operation. But he forgot to ensure that his INFORMATION_SCHEMA database would not be exposed and readable... That leads us to fully readable server variables like version used (10.1.26-MariaDB-0+deb9u1 - pretty ancient DB and OS, I'd assume). From here you can go south and do some kinky stuff, if you want and have knowledge for that. But who cares, right?   Ooh, table core_pfields_content field_6 is IP address which is checked by FORUM_USER_ID. Yep, you can query all IP addresses there (124 of them right now) and also do whatever you want with them! 🙂  The most fun part? Files source has been shared what, more than 2 years ago?  Vilmis still uses very same credentials and never changed it after sources exposure - who cares. Although, "sources" may be way too strong word here. If anyone still use paid Orion versions, I'd suggest packing your shit and leaving immediately, or at least fix this incompetent fool caused problems. It's obvious Vilmis don't care or maybe doesn't even know from the first place how to solve this problem (hint hint - tiny PHP Rest API microservice which would do absolutely the same but without exposing sensitive data?). By doing that, he exposes his infrastructure and YOUR data, and he does that for more than 2 years now 🙂 Developer of century!    
    • rename the l2.bin into l2.exe
    • L2LIVE.PRO- Dynamic Mid-rates Essence Seven Signs GRAND OPENING - July 5, 20:00 GMT+3 (EEST) TEST SERVER IS OPEN - COME AND CHECK IT OUT TODAY! Join our community and be part of it at: https://www.l2live.pro https://discord.gg/k3NMgR4Dmu   Server description * EXP/SP: Dynamic (x1- x100 based on your level, *before* Sayha and EXP buffs * Adena: x50 / Item Drop: x10 / Fishing EXP increased / Attribute EXP increased * Simplified gameplay to stay in the loop while not spending hours and hours farming * Starter Pack containing very useful items for beginners * MP replenishing potions with auto-consumption * No overpowered donations L2LIVE shop * All spellbook coupons, pet spellbook coupons and master books are sold via Game Assistant * Additionally you can buy SP pouches, enchanted talismans, pet training guides and various other consumables for Adena and L-Coin * More items such as cloaks, more talismans, agathions, belts, pendants, enchantment scrolls of various grades, evolution stones, etc will be added! Shop server as a shortcut, and all retail-like ways of earning items are still here! L-Coins * Drops with small change and in random amounts from Lv60+ monsters  * All raidbosses drop random amount of L-Coin Pouches generating up to 420 Lcoin per unit. **Grand Olympiad and Events** * Grand Olympiad is held week day * Format is 1v1, unlimited weekly fights  * Heroes are declared weekly at Sunday * There are three automated events - TvT, CTF and Deathmatch, running at evenings * Orc Fortress, Battle with Balok, Keber Hunter, Archievements Box, Daily Gift Calendar provisional events are active too Custom user commands * .offlineplay command, your character will keep playing till death or server restart * .offlineshop command, keeps your shop sitting until all items are purchased * .apon / .apoff - enable/disable HP/MP autoconsume And lots of other small improvements are waiting for you!   Join our community and be part of it at: https://www.l2live.pro https://discord.gg/k3NMgR4Dmu
  • Topics

×
×
  • Create New...