lundi 10 décembre 2007

Surcharger une méthode d'extension

Les surcharges de méthodes d'extension

Préambule

L'article a nécessité une correction post-publication le 2 décembre. Il m'a paru important de conserver le contenu initial de ce dernier par transparence vis-à-vis des premiers lecteurs mais aussi parce que l'erreur commise a un intérêt pédagogique. Un chapitre « Mise à jour » a donc été ajouté en fin d'article, le reste n'ayant pas été modifié.


Rappel sur les méthodes d'extension
Pour définir une méthode d'extension, il suffit de créer une classe statique. Ensuite, le premier paramètre de chaque méthode sera « balisé » par le mot clé « this » afin de désigner le type de l'objet que l'on souhaite « étendre ».Prenons un exemple. Soit un objet « Personne » ayant pour propriétés : un prénom, un nom et un âge.
public class Personne
{
public string Nom { get; set; }
public string Prenom { get; set; }
public int Age { get; set; }
}Si vos objets sont alimentés par différentes sources, vous vous apercevrez que le nom est parfois en majuscule, parfois en minuscule, ce qui vous posera problème par exemple pour écrire de façon standard un courrier sous Word.
List personnes = new List();
personnes.Add(new Personne(){Nom="DURAND",Prenom="Cyril",Age=21});
personnes.Add(new Personne() { Nom = "Kempé", Prenom = "Laurent", Age = 36 });
personnes.Add(new Personne() { Nom = "MELANTOIS", Prenom = "Frédéric", Age = 38 });
personnes.Add(new Personne() { Nom = "Perfetti", Prenom = "Michel", Age = 30 });Pour nos documents, nous aimerions bien avoir une méthode « PrenomNom ()» dans la classe « Personne », permettant d'avoir le prénom puis le nom en majuscules. Mais dans bien des cas, vous n'aurez pas la possibilité de réécrire cette classe. Les méthodes d'extension viennent alors à notre secours :
namespace EspaceDeNom1
{
public static class ExtensionPersonne
{
//prénom + Nom en majuscule
//[//System.Runtime.CompilerServices.Extension]
public static string PrenomNom(this Personne p)
{
StringBuilder s = new StringBuilder(p.Prenom);
s.Append(" ");
s.Append(p.Nom.ToUpper());
return s.ToString();
}
}
}Veuillez noter que le compilateur C# refuse l'utilisation de l'attribut « System.Runtime.CompilerServices.ExtensionAttribute » contrairement à Visual Basic. La seule façon de créer une méthode d'extension est d'ajouter le mot clé « this ». Sous le capot, comme nous avons pu le voir dans un précédent article, le « this » est retranscrit en attribut sur la classe et la méthode statique au niveau de l'IL (Intermediate Language).Le compilateur permet un usage aisé de la méthode :
foreach (string identite in from p in personnes select p.PrenomNom())
{
Console.WriteLine(identite);
}Ce qui nous donne le résultat suivant :

Nous pouvons constater qu'un des noms comporte une majuscule avec accent, ce qui ne nous convient pas. Imaginons que nous ne sommes pas en possession des sources de la méthode d'extension ou que celle-ci se trouve dans une assembly déjà déployée. Nous avons très largement employé la méthode d'extension « PrenomNom() » un peu partout dans notre projet. Celle-ci satisfait nombre de vos collègues mais pas vous dans votre propre utilisation. Vous pouvez alors soit modifier son utilisation par un remplacement systématique par une autre méthode soit « surcharger » la méthode d'extension. Cette dernière solution est bien évidemment bien moins lourde !
Surcharger une méthode d'extension
La surcharge d'une méthode d'extension est possible sous certaines conditions. Celle-ci doit se trouver dans la même assembly et le même espace de nom que l'appel à la méthode d'extension. Si ces conditions ne sont pas remplies, le compilateur renverra une erreur signifiant un appel ambigu de méthodes d'extension. Ecrivons rapidement une méthode d'extension (la performance extrême dans les exemples n'est pas l'objet de l'article)
public static class ExtensionPersonne
{
internal static string UpperToStandardUpper(this string chaine)
{
string accent = "ÀÁÂÃÄÅÇÈÉÊËÌÍÎÏÑÒÓÔÕÖØÙÚÛÜ";
string sansAccent = "AAAAAACEEEEIIIINOOOOOOUUUU";
char[] tableauSansAccent = sansAccent.ToCharArray();
char[] tableauAccent = accent.ToCharArray();
for (int i = 0; i < accent.Length; i++)
{
chaine = chaine.Replace(tableauAccent[i].ToString(), tableauSansAccent[i].ToString());
}
return chaine;
}

public static string PrenomNom(this Personne p)
{
StringBuilder s = new StringBuilder(p.Prenom);
s.Append(" ");
s.Append(p.Nom.ToUpper().UpperToStandardUpper());
return s.ToString();
}
}Si nous ajoutons ce code dans le même espace de nom que l'appel, une surcharge de méthode d'extension s'opère. De sorte que la requête suivante :
foreach (string identite in from p in personnes select p.PrenomNom())
{
Console.WriteLine(identite);
}renvoie :

Nous venons de réaliser avec succès une surcharge de méthode d'extension. Cet aspect nous apparaît bien pratique. Toutefois, sachez que bien évidemment vous pouvez passer outre par l'invocation direct des méthodes :
foreach (string identite in from p in personnes select EspaceDeNom1.ExtensionPersonne.PrenomNom(p))
ou
foreach (string identite in from p in personnes select ConsoleApplication1.ExtensionPersonne.PrenomNom(p))
Résoudre les éventuels conflits
Les méthodes d'extension sont très séduisantes mais peuvent générer des conflits. En effet, il suffit d'utiliser deux espaces de noms différents comportant une signature de méthode d'extension identique. C'est alors que le compilateur génère une erreur d'appel ambigu de méthodes d'extension. Comment éviter au maximum ces conflits ? Comme le suggère la documentation MSDN, il faut rassembler ses méthodes d'extension sous un même espace de nom bien évocateur : « Extensions ». Si ceci est une bonne pratique, car elle permet de localiser très rapidement l'ensemble de vos méthodes d'extension, cela n'évitera pas les conflits si un éditeur de logiciel a créé une même signature que vous. Une solution peut être de préfixer chacun de vos noms de méthode d'extension. C'est à vous de bien penser au nom que vous allez donner à votre méthode. Il existe une solution pour limiter l'impact de vos méthodes d'extension, c'est de changer la portée de « public » à « internal ». Nous l'avons vu dans un précédent exemple avec la méthode « UpperToStandardUpper ». Sa portée est donc limitée à l'assembly de sorte que les utilisateurs de cette dernière n'ont pas accès à cette méthode et n'auront donc pas de conflit. C'est une pratique à généraliser dès les premières heures d'utilisation de c# 3.0 ou de Visual Basic 9
Un exemple de surcharge de méthodes d'extension de Linq
Dans certains cas, il peut être intéressant de surcharger une méthode d'extension. Si vous lisez cet article, vous avez sans doute déjà utilisé Linq et en particulier Linq to SQL. Pour ceux d'entre vous qui l'utiliseront, se posera une problématique concernant la couche d'accès aux données que vous aurez construite. En effet, si nous proposons une méthode renvoyant un IEnumerable dans notre DAL
public IEnumerable GetPersonnes()
{
DataClasses1DataContext t = new DataClasses1DataContext(_myDatabaseConnectionString);
var c = from h in t.PERSONNEs select h;
return c;
}Vous ne pourrez empêcher personne d'écrire dans la couche de présentation ceci :
IQueryable q = (IQueryable) MyDAL.GetPersonnes();
var r = from s in q where s.Personne_Age > 30 select s;ce qui aura pour incidence de créer un nouvel accès à la base de données par l'usage du IQueryable. Pour éviter, cette problématique, il faut que notre couche d'accès ne renvoie que des IEnumerable aucunement IQueryable. Nous pouvons réitérer de manière à ne plus avoir d'IQueryable de la façon suivante :
public IEnumerable GetPersonnes()
{
DataClasses1DataContext t = new DataClasses1DataContext(_myDatabaseConnectionString);
var c = from h in t.PERSONNEs select h;
return from i in c.AsEnumerable() select i;
}Mais si nous devons appliquer ces changements à chaque méthode de notre couche d'accès, ce travail devient fastidieux et nous risquons d'en oublier. La surcharge de méthodes d'extension peut venir à notre secours dans ce cas, en surchargeant la méthode d'extension « Select » de Linq To Objects. Voici le code de la surcharge :
internal static class ExtensionLinq
{
internal static IEnumerable Select(this IEnumerable source,
Func selector)
{
IEnumerable sourceEnum = source;
foreach (TSource s in sourceEnum)
yield return selector.Invoke(s);
}
}Cette surcharge permet de ne plus avoir à ce soucier dans la couche de présentation des manipulations telles que :
IQueryable q = (IQueryable) MyDAL.GetPersonnes();
var r = from s in q where s.Personne_Age > 30 select s;Elles deviennent impossibles. De sorte, que les requêtes Linq en couche de présentation ne se font qu'en mémoire. Vous aurez remarqué que j'ai pris soin d'écrire ma surcharge avec la portée « internal » de sorte qu'il n'y ait pas d'erreur d'appel ambigu de méthodes d'extension dans ma couche de présentation en faisant usage de Linq.
Mise à jour du 2 décembre
Je tiens vivement à remercier Flavien pour m'avoir notifié une ligne de code inutile. En ont découlé des discussions très instructives avec Flavien CHARLON et Matthieu MEZIL qui m'ont amené à retester différents cas de figure et à montrer que la surcharge du « Select » pour « Linq To SQL » n'était pas une solution satisfaisante.Rappelons le code proposé :
internal static class ExtensionLinq
{
internal static IEnumerable Select(this IEnumerable source,
Func selector)
{
IEnumerable sourceEnum = source;
foreach (TSource s in sourceEnum)
yield return selector.Invoke(s);
}
}la ligne « IEnumerable sourceEnum = source; » est complètement inutile car le « yield return » fabrique sous le capot un objet privé implémentant IEnumerable et non IQueryable. Voici le code que j'aurai dû écrire :
internal static IEnumerable Select(this IEnumerable source,
Func selector)
{
foreach (TSource s in source)
yield return selector.Invoke(s);
}On pourrait être satisfait mais le Select ne fonctionne pas comme on le souhaiterait. En effet, si au lieu de renvoyer toutes les colonnes de la table Personne, nous sélectionnons uniquement le nom par exemple :
var c = from h in dt.PERSONNEs where h.Personne_Age > 30 select h.Personne_Nom;La requête effectuée vers la base de donnée renverra toutes les colonnes avant que n'opère le « Select » que nous avons écrit. Cette solution n'est donc pas satisfaisante. Si l'on souhaite que la base de données ne renvoie que les colonnes que l'on a réellement besoin, il faut faire appel à la méthode d'extension « Select » de « System.Linq.Queryable » :
internal static IEnumerable Select(this IQueryable source,
System.Linq.Expressions.Expression
{
IQueryable iq = Queryable.Select(source, selector);
foreach (TResult s in iq)
yield return s;
}Si vous utilisez le Debugger ou le système de log du « DataContext », vous pourrez constater que cette surcharge répond désormais à notre exigence.Toutefois, les discutions avec mes camarades m'ont amené à effectuer de nombreux tests. J'ai alors pu constater que cette surcharge ne fonctionnait pas dans certains cas. Par exemple, si vous écrivez une requête du style « select * from matable where condition », le compilateur ne génèrera que « Table.Where(condition) » car le « Select » est inutile car toutes les colonnes sont demandées. On peut donc se féliciter d'un tel comportement pour ce qui est de la performance. Mais, la surcharge que je vous propose, ne fonctionne donc pas dans tous les cas. Je vous recommande donc de ne pas l'employer dans votre couche d'accès. Vous pouvez écrire une méthode d'extension qui empêchera de pouvoir requêter de nouveau via « Linq to SQL » :
internal static IEnumerable ToLinqToObject(this IQueryable source)
{
foreach (TSource s in source)
yield return s;
}Son utilisation se fera comme suit :
public IEnumerable GetPersonnes()
{
DataClasses1DataContext t = new DataClasses1DataContext(myDatabaseConnectionString);
var c = from h in t.PERSONNEs where h.Personne_Age > 30 select h;
return c.ToLinqToObject();//return from i in c.AsEnumerable() select i;
}

source : http://www.techheadbrothers.com/

dimanche 2 décembre 2007

Segmentation du marché et Personas

La segmentation du marché et les personas sont deux outils différents ayant chacun leurs propres objectifs. On écoute souvent dire : « je travaille déjà avec des personas, parce que je segmente mon marché ». En réalité, alors que la segmentation de votre marché vous aide à cibler des clients potentiels qualifiés, les personas, eux, vous aident à satisfaire ces clients potentiels. Votre objectif, en tant qu’éditeur de site web, est donc de combiner ces deux outils marketing pour, d’une part, générer la demande et d’autre part, satisfaire cette demande.
La segmentation du marché
La segmentation du marché consiste à trouver les meilleures façons de cibler et de délivrer des messages marketing qui créeront la demande. Une population de clients potentiels est segmentée en groupes qui, en raison de leurs différences, sont susceptibles de répondre à toute une variété de messages.
En raison de son objectif d’attirer l’attention du consommateur, de le persuader et de créer la demande, la segmentation du marché est basée sur des variables telles que l’âge, le genre, le revenu, le niveau d’éducation, les hobbies, la situation géographique, le style de vie, la personnalité psychologique... Cet outil est indispensable car il vous aide à définir comment parler efficacement aux différents groupes qui composent votre marché.
Les personas
Les personas, quant à eux, concernent la manière dont vos clients potentiels vont répondre à votre message. Les personas sont des segments définis principalement par les objectifs et les comportements de chaque groupe d’individus, car ces attributs sont les éléments les plus importants de la prise de décision. Les objectifs révèlent pourquoi les gens viennent sur votre site et ce qu’ils souhaitent y trouver, et les comportements montrent comment ils envisagent d’accomplir d’atteindre leurs objectifs. Par exemple, pour un site d’achat de biens immobiliers, si vous avez un segment dont l’objectif est de trouver un appartement, vous savez quels contenu et fonctionnalités proposer pour aider ce segment de population. Si vous connaissez le comportement de ce segment, comme, par exemple, s’il préfère principalement être contacté parce qu’il a trouvé l’appartement qui lui convenait sur votre site, vous pouvez prendre des décisions efficaces sur la manière de créer et structurer ce type de fonctionnalités et de contenu.
Synergie des deux outils
La segmentation de marché répond aux questions « Qui » et « Quoi » : qui ciblez-vous ? Quels produits ou services désirent-ils ? Que sont-ils susceptibles d’acheter et à quel prix ? Quels sont les outils marketing qui les atteindront le mieux ?... Une fois que vous avez répondu au « Qui » et au « Quoi », les personas vous aident à répondre aux questions du « Pourquoi » et du « Comment » : pourquoi ce produit ou service répond-il au besoin de la cible et pourquoi va-t-elle l’utiliser ? Comment va-t-on structurer le site pour qu’il satisfasse au mieux les besoins de la cible ? Comment être certain que le site réponde aux exigences de la cible tout en obtenant le chiffre d’affaires escompté ? Ces deux méthodes sont essentielles pour créer et implémenter une stratégie efficace pour votre site web, et sont plus performantes, naturellement, si elles sont employées ensemble. Plus vous incorporerez les personas suffisamment tôt dans le processus de segmentation de votre marché, plus le profil obtenu de vos clients potentiels sera complet.
En conclusion
L‘utilisation combinée de la segmentation du marché et des personas vous fournit une meilleure compréhension de vos clients, incluant la manière de les faire venir jusqu’à vous, et la manière de les satisfaire pour qu’ils puissent à nouveau revenir sur votre site. Ensemble, ces deux techniques sont votre meilleur atout pour réussir avec votre site web.

vendredi 23 novembre 2007

MIN_ACTIVE_ROWVERSION

Depuis l'arrivée du Service Pack 2 de Sql Serveur 2005, est apparue une nouvelle fonction appellée MIN_ACTIVE_ROWVERSION()
Cette fonction permet de renvoyer la prochaine valeur de type Timestamp à insérer dans la base de donnée.En comparaison avec ce qui se faisait avant le SP2, MIN_ACTIVE_ROWVERSION() correspond à la valeur renvoyée par @@DBTS + 1.
Note : Nous allons travailler avec un type timestamp. Sachez que ce type peut être aussi appellée rowversion. D'ailleurs les deux écritures sql sont correctes.
Prenons un exemple : Voici une table contenant une colonne de type timestamp

Create table Person.ClientWithRowVersion (version ROWVERSION)Nous allons insérer une nouvelle ligne dans cette table, puis faire une Select pour récupérer le résultat :
Insert Into Person.ClientWithRowVersion Values (DEFAULT)
Select * from Person.ClientWithRowVersionLe résultat est :
(1 row(s) affected) version
---------------------------
0x00000000000007D3Maintenant effectuons un test sur la valeur renvoyée par MIN_ACTIVE_ROWVERSION() et par @@DBTS
print 'MIN_ACTIVE_ROWVERSION : '
print MIN_ACTIVE_ROWVERSION()
print '@@DBTS'
print @@DBTS
------------------------------------------------------------------
MIN_ACTIVE_ROWVERSION :
0x00000000000007D4
@@DBTS
0x00000000000007D3Le résultat attendu est bien correct, MIN_ACTIVE_ROWVERSION() est bien la prochaine valeur insérée et @@DBTS la valeur en cours.
La où cela devient intéressant (et où l'on comprend l'intéret de cette nouvelle fonction) c'est lors de l'ajout d'une transaction dans notre exemple.Nous allons récupérer les valeurs PENDANT la transaction :
BEGIN TRAN

INSERT INTO Person.ClientWithRowVersion VALUES (DEFAULT)
SELECT * FROM Person.ClientWithRowVersion
GO

PRINT 'MIN_ACTIVE_ROWVERSION'
PRINT MIN_ACTIVE_ROWVERSION()
PRINT 'DBTS'
PRINT @@DBTS
GO

COMMIT

---------------------------------------
0x00000000000007D5

(1 row(s) affected)

MIN_ACTIVE_ROWVERSION
0x00000000000007D5
DBTS
0x00000000000007D5Que constatons nous ? Que la valeur de MIN_ACTIVE_ROWVERSION n'a pas été encore mise à jour, alors que celle de DBTS, si .
Là où cette implémentation est judicieuse, c'est lors de l'utilisation de cette fonction lors d'une synchronisation.L'un des principes lors d'une synchronisation, c'est la récupération des enregistrements de la base de données Source.Grâce à l'utilisation de MIN_ACTIVE_ROWVERSION() vous êtes sûr de ne récupérer que les enregistrements VALIDES par la base de données, et non des enregistrements en cours de validation et donc potentiellement incorrects...
Par Sébastien Pertus publié le 23/11/2007 à 11:00

Appels asynchrones en ADO.NET 2.0

ADO.NET V2 apporte une simplification appréciable pour exécuter de manière asynchrone des requêtes en BD pour l'espace de nom SqlClient.

L'exemple

Un peu à la façon des proxies Web Services générés automatiquement par Visual Studio 2003 lors de leur référencement, la classe « System.Data.SqlClient.SqlCommand » propose de nouvelles méthodes « Begin* » et « End* » permettant d'exécuter de manière asynchrone des requêtes sur une base de données SQL Server. Par exemple :
BeginExecuteNonQuery : le pendant de ExecuteNonQuery pour les requêtes actions asynchrones.
BeginExecuteReader : le pendant de ExecuteReader pour la récupération d'un jeu de données en asynchrone.Voici donc les grandes étapes pour récupérer un jeu de données de manière asynchrone sur SQL Server :
Etape 1 : création d'un délégué qui permettra de définir une signature afin de lier un IDataReader à une DataGridView : // Delegue definissant la mise jour la grille lors du callback
public delegate void ProcessDelegate(IDataReader dr);
Etape 2 : création de la méthode exécutée en fin d'appel asynchrone et qui utilisera le délégué précédent pour lier le IDataReader à la DataGridView. Vous noterez l'utilisation de la propriété « InvokeRequired » afin de vérifier si le handle du contrôle a été créé sur un autre Thread ou pas (utile pour la liaison puisque cette dernière ne peut se faire que sur le même Thread que celui qui a créé le contrôle) :
// Methode executee en callback

private void ExecuteOnCallBack(IAsyncResult result)
{
// Recuperation de la commande initiale passee en parametre lors du BeginExecuteReader
SqlCommand cmd = (SqlCommand)result.AsyncState;
SqlDataReader reader = cmd.EndExecuteReader(result);
// Verifie si le handle du controle a ete cree sur un autre Thread ou pas.
if (dataGridView1.InvokeRequired)
dataGridView1.Invoke(new ProcessDelegate(Process), new object[] { reader });
else
Process(reader);
}
Etape 3 : création de la méthode permettant de lier le IDataReader à la DataGridView selon le modèle défini par le délégué précédent : // Methode executee pour realiser la liaison de donnees

public void Process(IDataReader dr)
{
BindingSource source = new BindingSource();
source.DataSource = dr;
dataGridView1.DataSource = source;
dr.Close();
}
Etape 4 : Codage de l'appel asynchrone. Vous noterez la modification de la chaîne de connexion : « async=true » : private void Form1_Load(object sender, EventArgs e)
{
// La chaine de connexion doit etre positionnee dans un fichier de configuration. En dur dans le code, c'est Mal !
string connectionString = "data source=(local);initial catalog=Northwind;user id=sa;password=XxXx;async=true";
SqlConnection cn = new SqlConnection(connectionString);
cn.Open();
SqlCommand cmd = cn.CreateCommand();
cmd.CommandText = "sSelectOrdersDetail";
cmd.CommandType = CommandType.StoredProcedure;
// Appel asynchrone
IAsyncResult iar
= cmd.BeginExecuteReader
(
new AsyncCallback(ExecuteOnCallBack),
cmd,
CommandBehavior.CloseConnection
);
}
L'exemple que vous trouverez en attache permet d'exécuter une procédure stockée sur la base exemple Northwind sur SQL Server 2000. Vous noterez l'utilisation dur « WAITFOR » pour simuler un long traitement : CREATE PROCEDURE dbo.sSelectOrdersDetail
(
@OrderID INT = NULL
)
AS
BEGIN
WAITFOR DELAY '000:00:10'
SELECT [Order Details].*
FROM [Order Details]
WHERE ( (@OrderID IS NULL) OR (OrderID = @OrderID) )
END

Cet article a été réalisé sur les versions suivantes :
Framework .NET version 2.0.50215
Visual Studio 2005 version 8.0.50215.44 (beta2.050215-4400)
Par Frédéric Colin publié le 25/09/2005 à 20:01

mardi 6 novembre 2007

L'actualité des moteurs de recherche

Depuis près d'un an maintenant, Google intégre des sitelinks sous les sites de fort trustrank. Un sitelink étant constitué de liens internes de votre site, visibles en tapant uniquement le nom de votre domaine sans son extension dans une recherche sur Google.
En d'autres termes, si vous obtenez un backlink sur un site possédant un sitelink, ceci sera très bénéfique pour augmenter votre propre trustrank (indice de confiance Google).
A noter que ceci n'a rien à voir avec votre Pagerank, notion qui semble devenir de plus en plus obsolète malgré une mise à jour massive et souvent à la baisse de ceux-ci ces derniers jours.
Google propose maintenant, dans ses " Webmaster Tools " (rubrique " Links > Sitelinks ") une rubrique où les liens actuels sont affichés. Il est alors possible d'en ajouter d'autres ou de modifier ceux existant.

Microsoft prend des parts dans Facebook

Facebook, le nouveau réseau social en vogue qui fait parler de lui, vient d'être valorisé à 15 milliards de dollars grâce à Microsoft qui vient de prendre une participation de 1,6% de Facebook pour la modique somme de 240M$.
Facebook avait refusé précédemment 1M$ de Yahoo pour son rachat. En d'autres termes, cette petite participation empêche les autres acteurs intéressés par Facebook de rentrer facilement dans son capital (je parle de Yahoo et de Google), Microsoft obtenant ainsi une exclusivité publicitaire sur Facebook jusqu'en 2011.

Soirée Ref-Party 3ème édition

Le 11 Décembre 2007, une 3eme soirée Ref-Party aura lieu dans un espace exceptionnel de 700m2 pour y accueillir plus de 500 personnes. Nous y accueillerons le monde du référencement et de la publicité en ligne.
Les inscriptions seront disponibles début Novembre. Cette 3ème édition sera organisée par David BERDAH et Sébastien POULET-MATHIS.


Source :moteurzine.com

lundi 29 octobre 2007

F#: la programmation fonctionnelle orientée objet bientôt dans Visual Studio

Microsoft planche sur un langage de programmation fonctionnelle depuis quelques années déjà. Baptisé F#, il devrait être proposé dans une prochaine version de Visual Studio. C'est ce qu'a révélé le 24 octobre le responsable des développements Visual Studio chez Microsoft, S. 'Soma' Somasegar (dixit The Register). Ce langage s'adosse à Objective CAML. Une implémentation orientée objets du langage de programmation fonctionnel CAML élaboré par l'INRIA depuis 1985. Microsoft entend faire du F# un langage adapté aux développements complexes, dans le domaine l'informatique financière, scientifique et technique.

source : http://www.journaldunet.com/

vendredi 26 octobre 2007

C# SSII Spécialiste DotNet

Microsoft résume C# ainsi:
"C# est un langage orienté objet élégant et de type sécurisé qui permet aux développeurs de générer une large gamme d'applications sécurisées et fiables qui s'exécutent sur le .NET Framework. Vous pouvez utiliser C# pour créer, entre autres, des applications clientes Windows traditionnelles, des services Web XML, des composants distribués, des applications client-serveur et des applications de base de données. Microsoft Visual C# fournit un éditeur de code avancé et des concepteurs d'interfaces utilisateur pratiques, il intègre un débogueur et de nombreux autres outils qui accélèrent le développement des applications avec la version 2.0 du langage C# et le .NET Framework."Le langage et la plate forme de développement permet donc de développer:
- Des applications dite Web: intranet, extranet et internet. la caractéristique principale de ces applications reside dans le fait que l'on y accède par un navigateur web classique. Dans l'environnement de développement dotNet , il s'agit de développement informatique dit 'WebForm'.
- Des applications Winform: Ces applications, souvent client/serveur, sont moins indépendante du poste de l'utilisateur (Il faut souvent les installer) mais bénéficient de possibilités plus vastes en terme d'ergonomie et donc de richesse/productivitéCe qu'il faut aussi retenir de C#, c'est qu'il a été concu pour être orienté objet . Il s'appuie donc sur les concepts d'encapsulation, d'héritage et de polymorphisme, de classes...Fondement de la révolution initiée par C++ puis java, la notion d'objet, si elle est bien utilisée, permet de concevoir des applications plus robustes,communicantes et dont les 'objets' informatiques ainsi créés sont réutilisables. Les ingénieurs ont étudié depuis déjà plusieurs années ces concepts lors de leur formation.

mercredi 24 octobre 2007

Le web-marketing : Définition d'un projet de site Internet (étapes 1 à 3)

L’une des étapes fondamentales de l’élaboration d’un site web est la définition du projet en lui-même, permettant l’identification du périmètre initial du projet et l’établissement de l’organisation adéquate et des moyens nécessaires, tant humains, techniques que budgétaires, pour sa mise en application. Beaucoup de projets de création de sites internet échouent en raison du manque ou de l’absence de cadrage initial.

Cette étape est articulée autour de 5 tâches distinctes : l’étude des besoins et des attentes (audit préalable), la rédaction du rapport de synthèse, la rédaction du cahier des charges fonctionnel, l’élaboration du plan projet et le plan de maintenance du site. Nous ne rentrerons pas en détail dans toutes ces tâches, mais voici quelques conseils qui sauront vous orienter pour les 3 premières étapes.

1ère étape : Auditer votre client (ou vous-même)

Le but de cet audit préalable est de déterminer l’objectif primaire du projet et les objectifs secondaires, la ou les cibles, les objectifs liés à la perception de la marque, la nature du contenu du site, les spécificités techniques et la stratégie de communication. Il faut donc collecter le maximum d’informations lors de cette étape afin de pouvoir réaliser une étude approfondie du projet (faisabilité, étude de marché, de la concurrence) et conduire à l’élaboration d’un outil maximisé (le site) répondant efficacement à vos besoins et à ceux de votre cible.

Voici un modèle général de questionnaire :

1)Informations générales

- Nom du projet
- URL actuelle ou URL souhaitée
- Contacts pour le projet (nom, email, téléphone)
- Échéance de lancement du site
- Les facteurs externes pouvant influer sur l’échéancier

2)Pourquoi ?

- Quel est l’objectif que vous souhaitez atteindre avec ce projet (quelle problématique d’entreprise souhaitez-vous résoudre au travers de votre site web) ?

3)Pour qui ?

- Qui est votre cible ? Décrivez votre cible (CSP, usage d’Internet...)

4)Valeur

- Pourquoi votre cible aurait-elle besoin de vous ? Quel est son intérêt ?
- Qu’offrez-vous de mieux que votre concurrence ?
- Comment sont perçus vos produits/services par votre cible ?
- Comment votre cible utilisera-t-elle votre site ? Quels sont ses objectifs (ceux de la cible)

5)Perception

- Listez des adjectifs sur la manière dont vous souhaitez que votre cible perçoive votre nouveau site
- Qu’y a-t-il de différent par rapport à la perception actuelle de votre entreprise (ou ancien site web)
- Listez des sites web que vous aimez. Qu’aimez-vous dans ces sites ?

6)Le contenu

- Possédez-vous un contenu existant à fournir pour votre site ou est-ce un nouveau contenu ? Qui rédigera le nouveau contenu ?
- Quels sont les visuels dont nous devrons nous servir ? Existent-ils ou devrons-nous les créer (logos, photos, charte graphique...) ?

7)Technologie

- Quels types de technologies souhaitez-vous mettre en place pour votre site (Flash, AJAX...). Si tel est le cas, expliquez comment cela améliorera l’expérience des utilisateurs sur votre site.
- Aurez-vous besoin de fonctionnalités liées à une base de données (CMS pour mettre à jour par votre propre équipe certaines parties de votre site, personnalisation des connexions, espace privé...) ?
- Aurez-vous besoin de transactions sécurisées (dans le cadre d’un e-commerce) ?
- Aurez-vous besoin d’autres fonctionnalités de programmation, comme une fonction de recherche par exemple ?

8)Marketing et communication

- Comment souhaitez-vous que votre cible vous trouve ? Quels leviers initieront une visite (backlinks, incentive, résultats organiques, liens sponsorisés...) ? Si vous avez déjà un site web, comment communiquez-vous votre URL online et offline ?
- Avez-vous déjà une idée sur la stratégie marketing que vous souhaitez adopter pour promouvoir votre site ? Si oui, pouvez-vous nous la décrire ?

9)Mises à jour

- Comment allez-vous planifier la conservation du contenu actuel de votre site et sa mise à jour (dans le cas d’un site web existant) ?
- A quelle fréquence le contenu doit-il être mis à jour ?
- Qui est responsable de la mise à jour et de la rédaction des contenus ?
- Quel logiciel allez-vous utiliser pour vos mises à jour ?
- Notes et commentaires additionnels

10)Budget

- Quel est l’enveloppe budgétaire globale allouée au projet ?
- Comment est réparti le budget dans les différents postes de travail (audit, conception, réalisation, marketing & communication...)

2ème étape : Rédiger le rapport de synthèse

En vous appuyant sur les informations fournies lors de l’audit, rédigez une synthèse pour définir noir sur blanc les objectifs du projet, le profil de la cible, la perception de la cible, le message principal à délivrer et l’avantage compétitif. Voici une trame de rédaction :

1)Sommaire du projet

- Brève description du projet
- Objectifs et échéance de lancement
- Échéance estimée pour atteindre l’objectif commercial

2)Profil de la cible

- Profil de la cible (CSP, niveau d’usage d’Internet...)
- Usage général d’Internet par la cible
- Les besoins et les principaux centres d’intérêt de la cible

3)Perception de la cible

- Comment votre cible vous perçoit ?
- Comment souhaitez-vous que la cible vous perçoive ?
- Comment le nouveau site web permettra d’accéder à cette nouvelle perception ?
- Adjectifs caractérisant le nouveau site

4)Message

- Quel est le message principal à transmettre à la cible ?
- Comment sera transmis ce message ?

5)Avantage compétitif

- Quelles sont les différences avec la concurrence ?
- Quels sont les atouts du site web actuel ?

3ème étape : Le cahier des charges fonctionnel

A l’aide de l’audit préalable, un document exprimant les besoins fonctionnels du site et les différentes tâches que l’internaute aura à accomplir sur le futur site, afin que l’équipe technique du site sache ce qu’elle a à développer et surtout, comment elle doit le développer. Il est donc nécessaire de rechercher, caractériser et hiérarchiser chaque fonctionnalité du site. Ensuite, pour chaque fonctionnalité, une fiche technique sera rédigée comportant :

- L’intitulé
- L’objectif
- Une description précise
- Les critères d’appréciation de la réalisation
- La priorité d’élaboration

Source: moteurzine.com


mardi 23 octobre 2007

15 extensions de sécurité pour Firefox

Firefox de Mozilla
© Mozilla

Chiffrement, alertes de sécurité, définition de mots de passe, protection contre le phishing, le pharming, le spam, ou encore les keyloggers : 15 extensions simples d'utilisation pour Firefox.

Souvent mis en valeur pour sa sécurité, Firefox peut se caparaçonner plus encore grâce à l'ajout d'extensions utilisables directement depuis le navigateur. Disponibles depuis le site de Mozilla, en français ou en anglais, elles s'intègrent aisément pour sécuriser la navigation.

NoScript, Get jetable mail, SCM, PhishTank SiteChecker, Gmail S/MIME, KeyScrambler Personal, SafeDownload, et de nombreuses autres.

lundi 22 octobre 2007

Oracle améliore les accès PHP à sa base de données

L'éditeur publie une nouvelle version d'Oracle Call Interface (OCI8) pour PHP : l'interface qu'il propose pour gérer les accès à sa base de données depuis des applications basées sur le langage de script côté serveur. Au chapitre des améliorations apportées à cette nouvelle édition : la prise en compte et la gestion de connections en provenance de pool de serveurs PHP. Une évolution qui vise à répondre au besoin croissance d'applications PHP en environnement critique.

Zend Studio est décliné pour Eclipse

Zend Technologies dévoile une version adaptée à l'infrastructure Eclipse de son environnement de développement PHP, Zend Studio. Le produit est basé sur le plug-in pour PHP récemment lancé par la fondation Eclipse : PDT (PHP Development Tools). Pour l'heure en version beta, la solution de Zend Technologies devrait être commercialisée début 2008. Zend Studio pour Eclipse permet aux utilisateurs de cet environnement de tirer parti des fonctionnalités d'Eclipse.

Parallèlement, Zend a annoncé en lien avec Microsoft un composant de services (FastCGI) permettant d'exécuter en natif des applications PHP sur le serveur Web IIS.

Visual Studio : vers une amélioration de l'analyse de code

Microsoft vient d'annoncer sa volonté d'améliorer les dispositifs d'analyse de code de son environnement de développement. Cette évolution sera mise en œuvre au sein de la prochaine version de l'application, Visual Studio 2008. Aux côtés des outils d'analyse statique Managed Code Analysis et C/C++ Code Analysis, l'éditeur prévoit d'ajouter une bibliothèque d'indicateurs d'analyses (Cyclomatic Complexity, Depth of Inheritance, etc.), ainsi qu'une fenêtre d'outils de navigation pour traquer les portions de code non-maintenables ou trop complexes.