Arhiva za SMF (Simple Machine Forum)

Kako pomoći korisnicima Jednostavno Ugradjeno Videos na SMF Mapa

Posted in SMF (Simple Machine Forum) by ShortLikeAFox na 10 kolovoz, 2008

Pa ti si zadužen za postavljanje Simple Machines Forum temelji site-a i želite siguran način da omogući korisnicima da ukopavati videe iz popularnih video sučelja (YouTube, Google Video, IGN, itd.). Vi svibanj biti opravdano bojati u dopuštajući korisnicima da jednostavno koristiti ukopavati kôd od onih pojedinačnih stranica, jer Bog zna što će biti rezultati. Rješenje za ovaj problem je kao jednostavan kao što može biti. Karl Benson napisao modifikacija paket koji omogućuje video ugradnja jednostavna isto kao rezanje i lijepiti URL stranice videu se pojavljuje u. Ovaj paket radova za više od 150 sučelja i zove AEVAC (Audio Ugradjeno Video / Audio isječci). Najnovija verzija 3.1.2 release je i može se naći ovdje.

To je mod JA visoko preporučiti. Koristi se točno ona ima potencijal da u velikoj mjeri smanjiti učestalost i težini glavobolje administrator foruma.

Kako se ručno Umetni grupu korisnika u SMF forum Koristeći PHP

Posted in SMF (Simple Machine Forum), PHP by ShortLikeAFox na 30. srpnja 2008

Tutorial To pretpostavlja da su upoznati s mojim post: kako se ručno Umetni Korisničke u SMF Forum Koristeći PHP.

Nedavno sam suočena s izazovom kreće 800 ili tako bendova iz baze podataka u SMF forum. Ja suočio par problema prilikom premještanje da nisam pokriće u prvom post:

  1. Bend imena nisu jamstvo da će vam biti sigurno za znak po znak kretati u SMF database. Dakle nekakav naziv mijenjanja funkcije morali biti zaposleni.
  2. The bands nemate lozinke. Tako neki tip lozinka naraštaj mora biti zaposlen.

Koraci sam o da se registruju sve ove bendove na forumu ode malo ovako:

Otvorite Band Database

za svaku (Band) (

Generirajte Lozinka

Preimenuj Band sa "sigurnom" ime

Grab generirajte i informacije potrebne za umetanje korisnik

Umetni Band u smf_members

Band Pošalji poruku e-pošte s lozinku

)

Informacije sam imao na raspolaganju bazu podataka iz benda koji je bio koristan uključeno: bandName, bandEmail i bandWebsite

Ovdje je funkcija generiranje zaporke sam koristio (blatently preuzet iz totallyphp.co.uk):

createRandomPassword function () (

znakova $ = "abcdefghijkmnopqrstuvwxyz023456789";

() * 1000000); srand ((double) microtime () * 1000000);

$ i = 0;

$ pass = ";



dok ($ i <= 7) (

33; $ num = Rand ()% 33;

$ tmp = substr ($ znakova, $ num, 1);

$ pass = $ pass. $ tmp;

$ i + +;

)

povratak $ pass;

)

Lozinka stvorio ovdje je relativno slab, ali je dovoljno dobar za moje potrebe. Bilo koja funkcija generiranje zaporke bi raditi fino ovdje. Sam izabrao ovaj neki, jer bi se lako za članove zapamtiti ako su izabrali da ne promijenite.

Kako ćete to učiniti:

/ / First spojiti na bazu benda
$ username = "bandUsername";
$ host = "bandHost";
MojaLozinka $ = "bandPassword";
$ db_name = "bandDatabase";

("cannot connect to server"); mysql_connect ( "host $", "$ username", "$ MojaLozinka") ili umrijeti ( "ne može spojiti na poslužitelj");
("cannot select DB"); mysql_select_db ( "$ db_name") ili die ( "ne mogu odabrati DB");

/ / Sada zgrabite sve od bendova iz baze podataka
$ query = "SELECT * FROM allBands";
$ bendova = mysql_query ($ query) or Die ( "Config 2222b Greška");
$ userRows = mysql_num_rows ($ bendova);

/ / Sada omogućuje spajanje na SMF db
$ host = "smfhost"; / / host name
$ username = "smfuser; / / mysql username
MojaLozinka $ = "smfpassword"; / / mysql password
$ db_name = "smfdatabase"; / / Database ime

("cannot connect to server"); mysql_connect ( "host $", "$ username", "$ MojaLozinka") ili umrijeti ( "ne može spojiti na poslužitelj");
("cannot select DB"); mysql_select_db ( "$ db_name") ili die ( "ne mogu odabrati DB");

/ / $ vaild_chars će biti niz znakova Dozvoljeno za korisnička imena. Sam odlučio dopustiti samo slova i brojeve. Postoje i druge znakove koji bi se mogla koristiti da ne bi uzrok problema, ali za stil razloga sam odlučio poći sa samo slova i brojeve
$ valid_chars = "abcdefghijklmnopqrstu vwxyz 0 1 2 3 4 5 6 7 8 9";
$ valid_chars = eksplodirati ( "", $ valid_chars);

/ / Sada trebamo petlju kroz svaki bend

){ for ($ i = 0; $ i <$ userRows; $ i + +) (

($bands)){ if ($ row = mysql_fetch_assoc ($ bendova)) (

/ / Izvuci benda informacije
extract ($ row);
/ / Create a password za bend
$ realPassword = createRandomPassword ();
/ / Echo sam odabrati da se bandname i lozinku kao dio moje debugging i tako da mogu vidjeti kako to radi funkcija
echo ( "$ <br/> bandName - $ realPassword");
newBand $ = "";
/ / Za svako slovo u imenu benda ćemo gledati da vidim ako odgovara važećim znakom od $ valid_chars. On to ne ćemo odstraniti ga i izrežite band name
($bandName); $j ++ ){ for ($ j = 0; $ j <strlen ($ bandName); $ j + +) (

($band[$j])); $ temp = str_replace ($ valid_chars, "X", strtolower ($ band [$ j]));
if ($temp == "X")

newBand $ = $ newBand. bend $ [$ j];

)
/ / Echo sam novo ime za istog razloga sam odjek starih ime i lozinku
echo ( "- $ newBand");
/ / Mi smo novi band name .... Počnimo sada buliding informacije su nam potrebne za umetanje u db ...
memberName $ = $ newBand;
realname $ = $ newBand; / / set sam pravi naziv i član istog imena. The bands mogu promijeniti ako žele
emailAddress $ = $ bandEmail;
websiteUrl $ = $ bandWebsite; / / Od Imam bendova 'kao i web stranice mogu upisati ih
websiteTitle $ = $ newBand;
$ is_activated = 1;
$ ID_POST_GROUP = 4;
($memberName).$realPassword); //Password must be encrypted $ password = sha1 (strtolower ($ memberName). $ realPassword); / / Zaporka mora biti šifriran

/ / Pobrinite njihovu nije član s istim imenom u SMF database. Ne želimo ući itko slučajno dva puta
$ query = "SELECT * FROM smf_members GDJE memberName = '$ memberName'";
("Config Error 2222343242b"); $ rezultat = mysql_query ($ query) or Die ( "Config 2222343242b Greška");
$ nrows = mysql_num_rows ($ rezultat);

/ / Ako je član ime je pronađeno ništa
if ($ nrows> 0) ()

else (

/ / Ako korisnik nije već prijavio za forume, učinite to i poslati e-mail ....
$ query = "INSERT NA smf_members (memberName, realname, emailAddress, is_activated, ID_POST_GROUP, passwd, websiteUrl, websiteTitle) vrijednosti ( '$ memberName', '$ realname', '$ emailAddress',' $ is_activated ',' $ ID_POST_GROUP ' , '$ password', '$ websiteUrl', '$ websiteTitle') ";

("Config Error 2232 "); $ rezultat = mysql_query ($ query) or Die ( "Config Error 2232");

/ / Sada nam je potrebna za slanje e-pošte grupe
$ to = $ emailAddress;
$ subject = "Vaše korisničko ime i lozinku forum";

/ / Od
$ header = "od: Me <me@mysite.com>";

/ / Vaša poruka
$ poruka .= "Vaše korisničko ime i zaporka su navedene u nastavku. možete promijeniti bilo kada, bilo u. Ako ne želite sudjelovati u našim forumima, to je bez problema. Samo ne prijavite i da će ikada biti kao ništa dogodilo . \ r \ n ";
$ poruka .= "Korisničko ime: Lozinka memberName $: $ realPassword \ r \ n";

/ / Slanje poruka e-pošte
$ poslanapošta = mail ($ to, $ subject, $ poruka, $ header);
if ($ poslanapošta)

echo ( "- Da!");
/ / Ovo je zadnji dio našeg odjek. The "-DA!" samo će se tiskati ako se šalje e-poštu. Tako potpuni ispis linija izgledati će otprilike ovako:
/ / Adam svađu - 4s6vsxag - AdamStrife - DA!

)

)
)

Kako se ručno Umetni Korisničke u SMF Forum Koristeći PHP

Posted in SMF (Simple Machine Forum), PHP by ShortLikeAFox na 28. srpnja 2008

Ovaj primjer je specifičan za SMF 1.1.5. I ne može jamčiti da će raditi sa bilo koje druge verzije.

Zato što pokrenete Simple Machine Forum Software i želite ručno unijeti korisnik? Nema problema. Znam taj problem izgleda vrlo specifičan, ali ideja je objašnjeno ovdje se može prilagoditi druge vrste forume database driven i drugih programskih paketa kao što su Wordpress. Prije nego što se upravo u tome, Let's pogledajte kako Simple Machine Forume vodi evidenciju o korisnicima. U SMF baza nalazi se tablica zove smf_members. The smf_members struktura izgleda ovako:

Polje Vrsta Null

Ključ Zadano Extra
ID_MEMBER mediumint (8) nepotpisan NE Pri NULL auto_increment
memberName varchar (80) NE MUL
dateRegistered int (10) nepotpisan NE MUL 0
postovi mediumint (8) nepotpisan NE MUL 0
ID_GROUP smallint (5) nepotpisan NE MUL 0
lngfile tinytext NE MUL
lastLogin int (10) nepotpisan NE MUL 0
realname tinytext NE
instantMessages smallint (5) NE 0
unreadMessages smallint (5) NE 0
buddy_list text NE
pm_ignore_list text NE
messageLabels text NE
passwd varchar (64) NE
emailAddress tinytext NE
personalText tinytext NE
spol tinyint (4) nepotpisan NE 0
Datum rođenja datum NE MUL 0001-01-01
websiteTitle tinytext NE
websiteUrl tinytext NE
mjesto tinytext NE
ICQ tinytext NE
AIM varchar (16) NE
YIM varchar (32) NE
MSN tinytext NE
hideEmail tinyint (4) NE 0
showOnline tinyint (4) NE 1
timeFormat varchar (80) NE
potpis text NE
timeOffset splavariti NE 0
avatar tinytext NE
pm_email_notify tinyint (4) NE 0
karmaBad smallint (5) nepotpisan NE 0
karmaGood smallint (5) nepotpisan NE 0
usertitle tinytext NE
notifyAnnouncements tinyint (4) NE 1
notifyOnce tinyint (4) NE 1
notifySendBody tinyint (4) NE 0
notifyTypes tinyint (4) NE 2
memberIP tinytext NE
memberIP2 tinytext NE
secretQuestion tinytext NE
secretAnswer varchar (64) NE
ID_THEME tinyint (4) nepotpisan NE 0
is_activated tinyint (3) nepotpisan NE 1
validation_code varchar (10) NE
ID_MSG_LAST_VISIT int (10) nepotpisan NE 0
additionalGroups tinytext NE
smileySet varchar (48) NE
ID_POST_GROUP smallint (5) nepotpisan NE MUL 0
totalTimeLoggedIn int (10) nepotpisan NE 0
passwordSalt varchar (5) NE

Polja koja treba obratiti pozornost na:

  • memberName - Samopomoć Explanitory.
  • dateRegistered - nije potrebno, ali ako ne ispunjenih datum registrirani prikazuje kao 31. prosinac 1969. Datum je spremljen kao vremensku epohu. Ne znam kako izračunati timestamps u tvoju glavu? Nema problema. Koristim slobodan generator naći ovdje.
  • realname - treba umetnuti. Kad nisam siguran sam ponoviti memberName ovdje.
  • emailAddress - Samopomoć Explanitory.
  • is_activated - mora biti postavljena na 1 jer smo ručno aktivirati član.
  • ID_POST_GROUP - neću lagati. Im 'ne siguran što je ovo, ali to uvijek izgleda kao da se podesiti na 4. Dakle .... Uvijek sam ga do 4. Nije najbolji način da se program, ali ono što mogu učiniti?
  • passwd - The lozinku želite dati novi korisnik. Nemoguće je shvatiti kako unijeti bez pogledati SMF dokumentaciju. Odgovarajući broj jedan za šifriranje SMF lozinku za bazu podataka izgleda ovako:

($memberName).$password) $ passwd = sha1 (strtolower ($ memberName). $ lozinka)

U gornji redak koda, $ password je stvarni korisnik lozinka.

Kako ćete to učiniti:

/ / Prvo spajanje na bazu podataka SMF

$ host = "hostname"; / / host name
$ username = "username", / / mysql username
$ MojaLozinka = "lozinka"; / / mysql password
$ db_name = "username", / / Database ime

("cannot connect to server"); mysql_connect ( "host $", "$ username", "$ MojaLozinka") ili umrijeti ( "ne može spojiti na poslužitelj");
("cannot select DB"); mysql_select_db ( "$ db_name") ili die ( "ne mogu odabrati DB");

$ memberName = "Ironman";
$ realname = "Tony ukočen";
$ emailAddress = "ironMan@ironMan.com";
$ is_activated = 1;
$ ID_POST_GROUP = 4;

$ password = "Tony1234";

($memberName).$password); $ password = sha1 (strtolower ($ memberName). $ password);

$ dateRegistered = 1216951200; / / 7/25/2008 2

$ query = "INSERT NA smf_members (memberName, realname, emailAddress, is_activated, ID_POST_GROUP, passwd, dateRegistered) vrijednosti ( '$ memberName', '$ realname', '$ emailAddress',' $ is_activated ',' $ ID_POST_GROUP ',' $ password ',' $ dateRegistered ') ";
("SMF Error 101.234 "); $ rezultat = mysql_query ($ query) ili die ( "Greška SMF 101,234");

To je sve što je na njega!