I-Am-Bot Code, technology and life

18Jul/096

Why Symfony is THE PHP Framework to work with

Posted by Srinath

I've spent the last few days fruitfully, searching and comparing the most popular and promising of PHP frameworks. Before I get started, I know the automatic follow up will be PHP bashing, and hailing RoR as the savior of the world. This post isn't about a rails vs PHP comparison, though I intend to write on that shortly.

27Jun/090

Sugar on a Stick

Posted by Srinath

What can be sweeter than a name with Sugar in it? Does it help that its for students, its open source and is fun too? Well then I'm definitely talking about "Sugar On A Stick" - A new initiative that aims to put accessible, fun software on a pen drive that students can carry around:

  • Sugar on a Stick as 1-to-1 computing in an elementary school
  • Sugar on a Stick to empower middle- and high-school students to help test, and learn computing platforms as learning tools
  • Sugar on a Stick for learning conferences to let people try Sugar and collaborate with other conference participants

Its based off Fedora 11, comes as a 380 MB ISO, and is primarily runs off your USB or CD media. The first release, tastily titled "Strawberry was released on 24th of this month. So here is to a great initiative, and I'll be taking it for a spin this week and get back with my thoughts.

Tagged as: , No Comments
27May/090

The best bug report EVER!

Posted by Srinath

This guy sure knows how to file a bug report

http://sources.redhat.com/ml/glibc-bugs/2009-05/msg00028.html

27May/091

Lightweight alternatives to phpBB

Posted by Srinath

phpBB is the holy grail of free and open source forum/discussion board on the internet. With tons of plugins, themes and a amazing community, its probably the best too. But for those like me who don't want the bloat, and would rather use a simple and easy to manage forum, here are a few alternatives:

1. SimpleMachines - Probably the second best known free forum script. Slimmer than phpBB, and with a better, cleaner admin interface, its my personal favourie. And yes, it does have its fair share of themes/plugins and good community support.

2. FluxBB - This one is "really" light. The download comes in under 300kb, is XTML and CSS valid, and with a minimal but delightful interface is bound to loved by Mac fans.

3. bbPress - Comes from the creators of WordPress, its their in house forum software. Nuff said.

4. Vanilla - Other than having a tasty name, it also offers a very small and simple forum. Great for "minimal" fans.

5. Phorum - Its an open source PHP forum. Probably not as good looking as the others, but does the job well.

7May/090

Javascript to generate query from form

Posted by Srinath

One of the most mundane tasks in web development is insertion of forms into databases. Writing a query for each form is cumbersome and isn't the best way to go about it. Now before I get started, there are "far better" ways of doing it like using datagrid, or form designers, etc. Since I don't find them suitable for my taste, I've put together a very simple javascript that can do the job.

My example is based on PHP/MySQL and uses jQuery

The Problem: Generating an Insert Query for the particular form. Traditionally, if you form had say 25 fields, you'll name them, and post/get them to a server side script like php. Then you have to get each field using the $_POST or $_GET variables, and generate the query. Imagine doing this for 25 fields! Hope you get the point.

The Solution: Automatically traverse the form, generate the query using javascript, then submit it to the server side script by Ajax POST using jQuery. The function takes 3 arguments: table name, success message, error message.

The Limitations: As you'd imagine, there are a few serious limitations:

  • The order of the form elements should match the order of the fields in the table. Needless to say the number of form elements should also match the number of fields in the table.
  • The database name is hard coded into the server side script. Since my work involves only a single database, I find it easier to keep things simple.

Steps:

1. In your normal HTML form, arrange the input boxes in the order that they appear in your database table. In this example, we have 3 text boxes: user, email and pass.

<div id="container">
<form id="loginForm" method="POST" action="dbprocess.php">
<dd>
<dl><label for="user">Username</label></dl>
<dt><input type="text" name="user" maxlength="20" /></dt>
</dd>
<dd>
<dl><label for="email">Email</label></dl>
<dt><input type="text" name="email" maxlength="20" /></dt>
</dd>
<dd>
<dl><label for="pass">Password</label></dl>
<dt><input type="password" name="pass" maxlength="8" /></dt>
</dd>
<input type="submit" value="Submit" id="submitForm" />
</form>
</div>

2. Include the jQuery.js and formSubmit.js files in the header

3. Insert the following Javascript code that disables the submit button of the form, and calls our formSubmit function instead. The form submission is handled in the function via jQuery Ajax request.

<script type="text/javascript>

$(document).ready(function(){
$("#loginForm").submit(function(){
return false;
});
$("#submitForm").click(function(){
formSubmit("users","New user added successfully!","Error adding user!");
});
});
</script>

4. Write your server side PHP script to connect to the database, and perform the operation

<?php
$query = stripslashes($_POST["query"]);

if(!$con = mysql_connect("localhost","root",""))
die("Database Connection Error");

if(!mysql_select_db("login"))
die("Database does not exist");

$result = mysql_query($query,$con);
if($result)
echo "1";
else
echo mysql_error($con);
mysql_close($con);
?>

And that's it! Your form insertion should be working provided you took care of the limitations. This script is useful if you have many forms with lots of input fields in your application. Comments, suggestions and criticisms welcome!

Download the script with example