Solved

Related question that allowed me to create this procedural code to loop through all the users

Posted on 2014-01-11
8
242 Views
Last Modified: 2014-01-12
Related question that allowed me to create this procedural code to loop through all the users

http://www.experts-exchange.com/Web_Development/Web_Languages-Standards/PHP/Q_28315794.html

// next create your Name Array
$input = array('user1','anotherUser', 'anotherUser2','bob');

foreach ($input as $uName) {
//from a config file. I decided to create object this each time to initiate the constructor
  $m_instance = new mam($config);
  $m_instance->default_username=$uName;
// works if all the users have 'password' as their password
  $m_instance->default_password='password';
  $m_instance->method();
//just to make sure that the instance is destructed
  unset($m_instance);
// needs } at the end of code to close the foreach
  }

Open in new window



problem is the code is procedural and I need to close the foreach bracket } at the end of code
and if password changes, it is hard coded

I want an object oriented class to do this.
0
Comment
Question by:rgb192
  • 4
  • 4
8 Comments
 
LVL 108

Expert Comment

by:Ray Paseur
Comment Utility
It looks to me like what you're doing here makes sense.  I'm not sure why you would want to change it.  The only thing that might change is that you would make the programming more complicated, and that's kind of the opposite of the objective of object oriented design, which is intended to make the programming simpler.

OOP and procedural code coexist beautifully, and it's the programmer's task to know what tool to use for the job at hand.  Sometimes you need a hammer, sometimes you need a wrench.

What you might consider is the use of setter() and getter() functions in concert with protected properties.  This would be better form than just injecting properties into the objects.  Good description and example here:
http://php.net/manual/en/language.oop5.visibility.php#108711
0
 

Author Comment

by:rgb192
Comment Utility
I think there should be a class with a constructor that accepts username and password.

Because if one user decides to change their password, this code requires if statements


I do not understand how setter and getter would work in this example

maybe set the username, password
and have the $mam class get the username,password

but I do not want to change the $mam class because I did not create it and class already works
0
 
LVL 108

Expert Comment

by:Ray Paseur
Comment Utility
... a class with a constructor that accepts username and password
That makes sense to me.  The class would probably look up the user record (based on the username and password) and load the user record into memory.  Perhaps it would store the user record information in the PHP session.  There could be a lot of user information.  For example you could connect the user to her viewing and purchase history, locale, and local business promotions.  You could create a social graph of friends.  All of these things could be created in the object at instantiation.

If() statements are not an evil.  They are an indispensable tool to control the flow of logic.

$mam would make sense as a variable name, but the class name would not have a dollar-sign.

Where is the Mam class defined?  Is this part of a tutorial or classroom lesson?  It's not familiar to me.
0
 

Author Comment

by:rgb192
Comment Utility
Where is the Mam class defined?  Is this part of a tutorial or classroom lesson?  It's not familiar to me.

custom code that interacts with our existing data to interact with users

If() statements are not an evil.  They are an indispensable tool to control the flow of logic.

I would prefer object oriented class so I could learn, how can username and pass be initialized if the password is different for every user

$input = array('user1','anotherUser', 'anotherUser2','bob');
$usernamePassword1 = array('user1','pass'),
$usernamePassword2 = array('anotherUser2','passAnother'),
$usernamePassword3 = array('anotherUser2','pass2'),
$usernamePassword4 = array('bob',bobpass');
0
Free Trending Threat Insights Every Day

Enhance your security with threat intelligence from the web. Get trending threat insights on hackers, exploits, and suspicious IP addresses delivered to your inbox with our free Cyber Daily.

 
LVL 108

Expert Comment

by:Ray Paseur
Comment Utility
Each different "user" (however that term is defined) would be represented by a unique object instance of some kind of "user" class.

What would you have us make of the code here?
http://www.experts-exchange.com/Web_Development/Web_Languages-Standards/PHP/Q_28336179.html#a39774985
0
 

Author Comment

by:rgb192
Comment Utility
Each different "user" (however that term is defined) would be represented by a unique object instance of some kind of "user" class.
okay the user class will have a constructor with two variables username and password


What would you have us make of the code here?
I created an example where each username had a different password.

I do not even understand how to do this with procedural if
maybe procedural case
and I think that there will be copy paste errors as new users are added.
0
 
LVL 108

Accepted Solution

by:
Ray Paseur earned 500 total points
Comment Utility
... will be copy paste errors as new users are added
This sounds like we are not getting the bigger picture.  Nobody adds "users" in any application by copying and pasting.  The usual design pattern is to store the user information in a data base table.  A cookie would be placed on the browser which was a key to the appropriate row of the table, and this would be used to retrieve the user information.  If the cookie was not present, the script would present a form to receive the username and password.  When the form is submitted, the script would try to find the username and password in the data base, and if found would place the cookie on the browser.  If not found, the login would be denied.
0
 

Author Closing Comment

by:rgb192
Comment Utility
database connection is an answer because only mam class has access to database
(does not work for me personally)

thanks


related question:
http://www.experts-exchange.com/Web_Development/Web_Languages-Standards/PHP/Q_28336597.html
0

Featured Post

How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

Join & Write a Comment

This article will explain how to display the first page of your Microsoft Word documents (e.g. .doc, .docx, etc...) as images in a web page programatically. I have scoured the web on a way to do this unsuccessfully. The goal is to produce something …
Part of the Global Positioning System A geocode (https://developers.google.com/maps/documentation/geocoding/) is the major subset of a GPS coordinate (http://en.wikipedia.org/wiki/Global_Positioning_System), the other parts being the altitude and t…
Learn how to match and substitute tagged data using PHP regular expressions. Demonstrated on Windows 7, but also applies to other operating systems. Demonstrated technique applies to PHP (all versions) and Firefox, but very similar techniques will w…
The viewer will learn how to dynamically set the form action using jQuery.

762 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

9 Experts available now in Live!

Get 1:1 Help Now